我曾经做了两年大型软件的维护工作,那个项目有10多年了,大约3000万行以上的代码,参与过开发的有数千人,代码checkout出来有大约5个GB,而且bug特别多,open的有上千,即使最高优先级的showstopper也有上百。

分享下我的debug的经验

1. 优先解决那些可重现的,可重现的bug特别好找,反复调试测试就好了,先把好解决的干掉,这样最节约时间。

2. 对于某些bug没有头绪或者现象古怪不知道从哪里下手,找有经验的同事问一下思路,因为在那种开发多年的大型系统里,经常会反复出现同样原因的bug,原因都类似,改了一处,过一阵子另外一处又冒出来,而且无法根治。
比如:我那个系统里有个特别危险的API,接口参数比较难用,一旦有人用错了某些情况下就会出诡异的现象,解决很简单,找到调用这个API的地方把调用方式写对就好了。为什么不根治呢?因为要保持兼容性不能改接口了。Windows系统里就好多这种烂API。
问下老员工吧,说不定他们都遇到过好多次了。

3. 放大现象,有些bug现象不太明显,那么就想办法增大它的破坏性,把现象放大。这只是个思路,具体怎么放大只能根据具体的代码来定。
比如:美剧《豪斯医生》里有一集,怀疑病人心肺有问题,就让病人去跑步机上跑步,加重心肺负担,从而放大症状。

4. 二分法定位,把程序逻辑一点点注释掉,看看还会不会出问题,类似二分查找的方法,逐步缩小问题范围。

5. 模拟现场,有时候我会问自己,如果我要实现bug描述的现象我要怎么写代码才行?
比如:我遇到一个死锁问题,但是检查代码发现所有的锁都是配对的,没有忘记解锁的地方,而且锁很简单就是一个普通的临界段,保护几行附值语句而已。这样的代码怎么写才能让他死锁呢?
我想如果让我故意制造这样一个现象,只有在上锁的时候强制杀掉线程了。
既然这样就可以去看看有谁强杀线程了没有。

6. 制作工具,针对某些bug编写一些调试辅助工具。
比如,我那个系统没有完善的崩溃报告,虽然也有dump,但是分析出来的callstack经常不准。于是我为解决崩溃问题编写了个工具,会自动扫瞄代码,在每个函数入口和出口插入log,以此来定位崩溃点。

7. 掩盖问题,虽然这样做有点不厚道,但是有时不得不这么做。有些bug找不到真正的root cause,但是又要在规定时间内解决,那么我们就可以治疗症状而不去找病因。比如用try catch掩盖一些奇怪的崩溃。不到万不得已不要这么干,未来可能会付出更大代价。

我在做这份工作的时候也在追美剧《豪斯医生》,豪斯大叔解决病症的思路和debug差不多,对我很有启发。

转载于:https://www.cnblogs.com/voidobject/p/3975571.html

(转)程序员新人怎样在复杂代码中找 bug?相关推荐

  1. 程序员新人怎样在复杂代码中找 bug?

    我曾经做了两年大型软件的维护工作,那个项目有 10 多年了,大约 3000 万行以上的代码,参与过开发的有数千人,代码 checkout 出来有大约 5 个 GB,而且 bug 特别多,open 的有 ...

  2. 程序员从复杂代码中找BUG的5种方法,你用过几个?

    有不少的新手程序员,刚开始都是从修BUG开始做起的. 修bug有助于熟悉项目,了解大概哪些类参与了执行线路,相互调用关系又是如何,结构设计上有什么特点. 对于新手程序员而言,在复杂代码中找BUG是一个 ...

  3. 中国首档程序员真人秀,20位选手找bug做模型,结果一开场主办方就惨遭攻击...

    金磊 杨净 发自 凹非寺 量子位 报道 | 公众号 QbitAI 终于!终于!终于! 以程序员为主题的综艺真人秀,真真儿的诞生了! 你以为是参赛选手都会是秃头.黑眼圈,21岁拥有40岁的面容? 图源: ...

  4. 程序员新人周一优化一行代码,周三被劝退?

    本文经沉默王二(id:cmower)授权转载 如若转载请联系原公众号 这周一,公司新来了一个同事,面试的时候表现得非常不错,各种问题对答如流,老板和我都倍感欣慰. 这么优秀的人,绝不能让他浪费一分一秒 ...

  5. 优秀的PHP程序员至少应该了解PHP代码的优缺点(转)

    我在SitePoint做面试官的时候一定会问的问题是:你认为PHP代码的优劣体现在哪里?因为这个问题可以让我大体知道应聘者是哪种类型的程序员,而不是单纯地考察他对PHP函数的掌握程度(这一点Zend的 ...

  6. [转]为什么程序员总是写糟糕的代码?这3个原因

    原文请看:为什么程序员总是写糟糕的代码?这3个原因 我最近一直在想我们作为一个行业为什么总是产出糟糕代码的原因. 1.明显原因-- 我一下子想到的最明显的原因是,有好的程序员,也有不那么好的程序员,有 ...

  7. 最受Linux程序员欢迎的7个代码编辑器的介绍及下载地址

    Linux平台上的代码编辑器太少了,Linux程序员经常抱怨,自从他们使用了免费开源的系统平台后,作为一名程序员,却并没有在代码编辑器上得到足够的重视.下面我们分享了7个最受Linux程序员欢迎的代码 ...

  8. 企业有了程序员为什么还要用 低代码/无代码

    一.备受"争议"的无代码/低代码开发 在看这篇内容时,我们要知道,技术无时无刻不在进行发展,IT技术更是如此,快速的技术更新使得程序员在进行应用开发时效率更高:我记得在十多年前,开 ...

  9. 别以为程序员的工作就是写代码

    大家好,我是鱼皮,今天给大家分享一个开发小经验. 很多没有实际工作过的同学,可能都会认为程序员的工作只有写代码 + 和产品经理 "拉扯",也会习惯性地用代码量来评价一个程序员的工作 ...

最新文章

  1. 指针02 - 零基础入门学习C语言42
  2. 容器生态系统 - 每天5分钟玩转容器技术(2)
  3. python -- IO多路复用
  4. hadoop集群搭建过程中不适用hostname发现slave,而是通过ip
  5. 阿里云Lindorm联合智臾科技发布,金融高频交易数据量化分析与处理方案
  6. 简易listview与adapter实现列表,ArrayAdapter和BaseAdapter
  7. Emulator Error: Could not load OpenGLES emulati...
  8. ds18b20温度传感器驱动编写
  9. mysql查询数据库报错sql_mode_MySQL数据库的sql_mode
  10. 面试官系统精讲Java源码及大厂真题 - 26 惊叹面试官:由浅入深手写队列
  11. 带你了解两种线性规划的方法:稀疏矩阵存储和预处理
  12. DataGridView默认不选中
  13. [译][Tkinter 教程15] event 事件绑定
  14. java学习(一)多态
  15. 《信号与系统学习笔记》—线性时不变系统(二)
  16. 计算机考研数据结构高分笔记,2021版天勤计算机考研高分笔记系列:数据结构高分笔记(第9版)...
  17. java soap服务_「java调用webservice」java调用webservice接口 三种方法 - seo实验室
  18. java代码实现简单的向企业微信发送信息
  19. 国内外知名的21个Logo设计工具
  20. 部署Elixir项目

热门文章

  1. 安装itunes需要管理员身份_Windows 10 在microsoft store 微软商店里安装的itunes如何更改备份位置...
  2. Sublime text别再弹出(wei zhu ce)以及(geng xin)提示了?
  3. 如何使用RS-232发射器和接收器?
  4. 【 MATLAB】Subspace algorithm Simulation of TOA - Based Positioning
  5. 【 C 】对指针表达式的个人总结与思考
  6. 用 TypeScript 编写一个 React 服务端渲染库(1)
  7. 动态调用WCF不添加服务(svcutil.exe)
  8. ubuntu 中安装memcache,并给出一个简单的实例·
  9. Android 用Animation-list实现逐帧动画
  10. Security issue about static code checking