传智专修学院社区

[IT资讯] 程序员新人怎样在复杂代码中找 bug?

2018-9-13 09:23
23817
程序员新人怎样在复杂代码中找 bug?

微信图片_20180913090350.jpg
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的方法吗?一起来讨论一下吧!
分享到 :
1 人收藏

17 个回复

倒序浏览
涛皇陛下  中级会员 | 2018-09-13 11:13:21
秘技:召唤神兽——> 钊哥
客客  管理员 | 2018-09-13 11:20:07
涛皇陛下 发表于 2018-9-13 11:13
秘技:召唤神兽——> 钊哥

毕业了怎么办?
无8108  中级会员 | 2018-09-13 12:10:56 来自手机
召唤度娘
奇瑞  注册会员 | 2018-09-13 12:11:18 来自手机
放大招  喊锤哥
贼帅的杨小煜  中级会员 | 2018-09-13 12:49:54 来自手机
电脑右下角有菜单栏,打开飞行模式,合上电脑,一手扔窗外去,让电脑飞一会
情叔.  注册会员 | 2018-09-13 13:58:54 来自手机
我写bug贼6
客客  管理员 | 2018-09-13 14:20:14

度娘能帮你找bug吗?
客客  管理员 | 2018-09-13 14:22:02
贼帅的杨小煜 发表于 2018-9-13 12:49
电脑右下角有菜单栏,打开飞行模式,合上电脑,一手扔窗外去,让电脑飞一会 ...

这个方法贼6
客客  管理员 | 2018-09-13 14:22:13

找bug呢?
涛皇陛下  中级会员 | 2018-09-13 14:29:17
客客 发表于 2018-9-13 11:20
毕业了怎么办?

Make a phone call to 钊哥
微醺  注册会员 | 2018-09-13 14:30:13 来自手机
我们不是bug的制造者,我们bug的搬运工
闹哪样  注册会员 | 2018-09-13 14:32:19
呼唤钊哥
客客  管理员 | 2018-09-13 14:34:09

钊哥要被你们气死了!
客客  管理员 | 2018-09-13 14:34:38
微醺 发表于 2018-9-13 14:30
我们不是bug的制造者,我们bug的搬运工

楼上还有一个写bug很6的
客客  管理员 | 2018-09-13 16:06:10
贼帅的杨小煜 发表于 2018-9-13 12:49
电脑右下角有菜单栏,打开飞行模式,合上电脑,一手扔窗外去,让电脑飞一会 ...

直接清缓存吧,代码全部重新写!
正在输入。。。  注册会员 | 2018-09-13 19:00:48 来自手机
钊哥:重启一下电脑就好了
恒2672  注册会员 | 2018-09-13 19:05:13 来自手机
最开始一行一行的输出语句查bug,哪行不输出就哪行错了。慢慢的嫌速度太慢就学着debug查看,用着用着就可以针对性的对报错区域debug。很方便   
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|小黑屋|传智专修学院社区 ( 苏ICP备16007882号-4  

返回顶部