如何快速查找BUG?
对于程序员而言,有一样东西是绝对不想碰见却又一定会遇到的,那就是Bug。
鲁迅曾经说过,当我们遇见Bug时要冷静,不要慌。
好吧,鲁迅并没说过这句话。开发应用程序是一个非常有压力的工作,没有人是完美的,因此在这个行业中,代码中出现bug是相当普遍的现象。
一个bug并不可怕
可怕的是发现一个bug,修改之后,会出现一群Bug,此时,我相信你的内心是崩溃的...
对于牛逼的程序员来说,可能会细细琢磨,保持冷静慢慢修复完。
“但是,这只是牛逼的程序员”含着泪也要把这句话加粗。
那么对于我们新手来说,碰到bug改怎么处理呢?
最近,我自己的一个大神朋友那里学到了几个方法,在这里分享给大家
△优先解决那些可重现的,可重现的bug特别好找,反复调试测试几次就好,先把好解决的解决了,这样最节约时间。
△对于某些bug没有头绪或者现象古怪不知道从哪里下手,找有经验的同事问下思路,因为在那种开发多年的大型系统中,经常会反复出现同样原因的bug,原因都十分类似,改了一处,过一阵子另外一处又冒出来了,而且无法根治。
△放大现象,有些bug现象不太明显,那么就想办法增大它的破坏性,把现象放大。这只是一个思路,具体怎么方法只能根据具体的代码来定。比如:美剧《豪斯医生》里有一集,怀疑病人心肺有问题,就让病人去跑步机上跑步,加重心肺负担,从而放大症状。
△二分法定位,把程序逻辑一点点注释掉,看看会不会出问题,类似二分查找的方法,逐步缩小问题的范围。
△模拟现场,有时候我会问我自己,如果我要实现bug描述的现象我要怎麽写代码才行?比如:我遇到一个死锁问题,但是检查代码发现所有的锁都是配对的,没有忘记解锁的地方,而且锁很简单就是一个普通的临界段,保护几个赋值语句而已。这样的代码要怎么写才能让他死锁了?我想如果我故意制造这样一个现象,只有在上锁的时候强制杀掉线程了。既然这样就可以去看看有谁强杀了线程。
△制作工具,针对某些bug编写一些调试辅助工具。比如,我的系统没有完善的崩溃报告,虽然也有dump,但是分析出来的callstack经常不准。于是我为解决崩溃问题编写了个工具,会自动扫描代码,在每个函数入口和出口插入log,以此来定位崩溃点。
△掩盖问题,虽然这样做有点不厚道,但是有时候不得不这样做。有些bug找不到真正的rootcause,但是又要在规定的时间内解决,那么我们就可以治疗症状而不去找病因。比如用trycatch掩盖一些奇怪的崩溃。万不得已不要这么干,未来可能会付出更大的代价。
而对于自己和别人写的bug,程序员的心理也是不一样的。
面对别人写的bug:卧槽,怎样一个沙比才能写出这样的bug,幸好有哥在,哥就是救世主!
面对自己写的bug:
别人发现:有bug,不能够啊!你测试过了吗?可以重现吗?我警告你不要搞事啊!真有啊?慌什么慌,谁没写过bug咋地?
自己发现:还好发现了,哥真是犀利!看看那群沙比,这么明显的bug都看不出来。
So,下次当你发现程序员写的代码出现bug时,请这样优雅的指出:
如何快速查找BUG?相关推荐
- 解决bug问题,查找bug的方法
想告别"写代码2分钟,找bug两小时"吗?,就必须掌握查找bug的能力 下面这些方法都是我这几年解决bug常用的 一.定位bug:如果在控制台中看不出bug,可以使用以下方法帮助查 ...
- Linuix 服务器cat log查看,快速定位 bug 最实用(实战总结)
背景: 当服务器上运行的项目出现异常时,为了提高工作效率,快速定位问题(bug) 至关重要.查日志常用命令cat必须懂得. cat 操作最实用写法: -- -n 显示行号 grep 查找关键字 -A ...
- 阿里软件测试工程师手把手教学—如何快速定位bug 编写测试用例?
作为一个测试人员,如果你连常见的系统问题都不懂得分析,频繁地把前端人员问题分配给后端人员,把后端人员问题分配给前端人员,那么你在团队发展中的地位是显而易见的,声誉.赏识.加薪应该是你遥不可及的梦想. ...
- java快速查找算法_Java实现的快速查找算法示例
本文实例讲述了Java实现的快速查找算法.分享给大家供大家参考,具体如下: 快速查找算法,可以根据想要找的是第几个大的数,每次循环都能固定下来一个数在数组完整排完序之后的位置,每次循环都能定一个数的位 ...
- python使用heapq快速查找最大或最小的 N 个元素
python使用heapq快速查找最大或最小的 N 个元素 heapq实现了一个适合与Python的列表一起使用的最小堆排序算法. 堆是非线性的树形的数据结构,有两种堆,最大堆与最小堆.( heapq ...
- Kali渗透测试——快速查找Metasploit的模块
快速查找Metasploit的模块 在渗透测试过程中,通过NMAP可以获取目标主机服务和操作系统信息:通过Nessus和OpenVAS可以获取目标主机存在的漏洞:或者,通过其他工具获取到关键信息.这时 ...
- win2003服务器记录文件夹,在Windows Server 2003里快速查找文件
用Windows Server 2003的Agent Ransack??专业文件定位器(File Locator Pro)应用程序快速查找文件. 随着各种规模的组织的数据存储需求不断增加,同时法规监管 ...
- 快速查找所有存储过程/触发器中是否包含某个字符串
select name from sysobjects o, syscomments s where o.id = s.id and text like '%CASIGN%' and o.xtype ...
- 【逆向分析】快速查找指定代码的几种方法
前言 每个人在调试中快速查找所需代码时都有不同的方法,但是最基本最常用的有下面几种. 学习这4种方法前我们需要思考一个问题.我们知道,运行HelloWorld.exe程序会弹出一个消息框,显示&quo ...
最新文章
- 休斯顿大学提出BCI-机器人(脑-外骨骼接口系统)可以改善运动恢复
- Java DICOM 网络传输_DICOM医学图像处理:fo-dicom网络传输之 C-Echo and C-Store
- 如何使用Chrome的Network面板分析HTTP报文
- html怎么控制进度条,HTML如何实现进度条?附源码
- ROS 教程之 network:多台计算机之间网络通信(2)
- 软件工程-东北师大站-第十一次作业(PSP)
- 正在等待继续编辑 - Python - 基础知识专题 - 配置文件与日志管理
- 金庸群侠传5 自动化脚本 绝情谷大厅开宝箱按键游戏
- android 解析rss,在Android中解析RSS源
- 左岸语不惊人死不休系列摘录
- 计算营业额python_告诉你怎么用Python进行企业营运分析!盈利这么多?
- 耐得住寂寞,是一种境界和品味
- Log4j2配置SMTP邮件实现邮件发送
- day05-python数字类型和列表
- 母婴购物微信商城的设计与实现
- csol霸主永恒python_昔日霸主沦为下水道?黑客编程告诉你谁是剑网3新赛季最惨门派!...
- 甲骨文开始审核 Java 许可问题:500 强企业“连夜”卸载 Oracle JDK
- HpM351a激光打印机加粉后,提示remove shipping lock from black cartridge的解决办法
- 重启人类超音速之旅 还有哪些技术问题待解?
- 【转】怎么在Linux上安装打印机驱动(以Ubuntu为例)