分享下我的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掩盖一些奇怪的崩溃。不到万不得已不要这么干,未来可能会付出更大代价。

最新文章

  1. LoadRunner函数示例:lr_paramarr_random()
  2. jquery.cookie.js 操作cookie实现记住密码功能的实现代码
  3. Bitmap四种属性
  4. Raspberry Pi --操作LED
  5. Microsoft Visual Studio 2012 文档 下载地址 vs2012 中文帮助文档
  6. Mac SVN ignore 等相关
  7. JAVA 中两种判断输入的是否是数字的方法__正则化_
  8. Shell 脚本编程
  9. 转:Ext GridPanel根据条件显示复选框
  10. 用POLL的方式,没有跑出结果来,立此存照
  11. 将实体转成XML,XML节点顺序由我控制
  12. BZOJ 3211: 花神游历各国( 线段树 )
  13. JPA 系列教程11-复合主键-2个@Id
  14. S0.1 【转】调色板
  15. skynet记录7:服务(c和lua)
  16. virtualenv虚拟环境
  17. HOW TO ANSWER: Tell Me About Yourself
  18. [No0000192]Vim打开和保存文件-Vim使用技巧(7)
  19. ActiveMQ漏洞利用方法总结
  20. OpenCV+VisualStudion2017配置

热门文章

  1. HDU 1712 ACboy needs your help (分组背包模版题)
  2. ThinkPHP C+F方式
  3. 获取某几个分类下的前N条数据 mssql语句
  4. UI:UITableView表视图
  5. 27.怎样在Swift中声明typedef?
  6. Ehcache(08)——可阻塞的Cache——BlockingCache
  7. 关于 TIdHttp
  8. 【M24】了解虚方法、多继承、虚基类、RTTI的成本
  9. 一次JQuery性能优化实战
  10. Linux中搭建SVNserver