修复bug的12个关键步骤_qq的bug修复在哪里-程序员宅基地

技术标签: 程序员  修复bug  程序员经验分享  bug  测试工具  开发者  

boss:那么,你需要多长时间来修复这个bug

    没有经验的程序员:给我一个小时?最多两个小时?我能马上搞定它!

    有经验的程序员:这么说吧,钓到一条鱼要多久我就要多久?!

  要多少时间才能修复bug,事先是很难知道的,特别是如果你和这些代码还素不相识的话,情况就更加扑朔迷离了。James Shore在《The Art of Agile 》一书中,明确指出要想修复问题得先知道问题的所在。而我们之所以无法准确估计时间是因为我们不知道需要多久才能发现症结的所在,只有清楚这一点,我们才能合理估计修复bug所需要花费的时间。不过,这个时候恐怕黄花菜都凉了。 Steve McConnell曾说过:

      “发现问题理解问题这就是程序员90%的工作。

  很多bug都只需改动某一行代码即可。但是需要投入大量时间的是,后面还得指出怎么样才是正确的——就像我们在钓鱼的时候,得知道往哪里下诱饵,什么时候鱼儿容易上钩等等。话说bug有四种类型:第一种易寻易修复,第二种难寻易修复,第三种易寻难修复,第四种难寻难修复。最悲剧的就是最后一型的,不但寻寻觅觅,凄凄凉凉戚戚,哪怕终于千辛万苦滴水穿石,也只能在那边不由自主地抓耳挠腮,无奈叹一句路漫漫其修远兮。可以这么说,除非是新鲜出炉的代码,不然让你找bug就跟瞎子摸象一样——糊里糊涂,不知道归属于哪种bug类型。



 

 

<!--[if !supportLists]-->一、        <!--[endif]--> 查找和修复bug

  你知道查找和修复bug”意味着什么吗?没错,就是调试!不断的调试,无数次的调试!Paul Butcher通过大量工作,总结出以下结构化的步骤:

1.明确目的。仔细查阅异常报告,确定是否是个bug,找出各种有用的信息发现问题的症结,予以重现。再次检查是否与报告发生重复。如果发生重复,那看看曾经的相关人员是如何处理的。

2.准备工作——找出正确的代码,用排除法清理工作区域。

3.匹配测试环境。如果客户正在操作计算机配置,那么此过程可以跳跃。

4.明确代码的用途,确保现有测试工具一切正常。

5.好了,现在可以出发钓鱼去咯——重现和诊断错误。如果你不能做到重现,那你就不能证明你已经完成修复工作。

6.编写测试案例,或者通过现成的测试案例来捕获bug

7.进入修复模式——请务必确保不会影响到其他任何部分。但是,在开展修复工作之前,可能你还要包揽重构工作,因为只有这样,你才能无所顾忌地捣鼓代码。而且事后回归测试,还能确保你不会加入任何新的bug

8.整理代码。通过一步一步重构,让你的代码更易于理解,更安全。

9.找别人来审查一下,当局者迷旁观者清。

10.再次检查此修复过程。

11.试着不从主线出发,以检查这些bug是否会影响其他支线。合并这些变化,处理代码中的差异,回顾所有的审查和测试等工作。

12.思考。好好想一想哪里错了以及为什么错了?为什么你的修复会起效?这种类型的bug还会出现在哪里?在《 The Pragmatic Programmer》一书中,Andy Hunt Dave Thomas也如是指出如果一个bug需要耗费你很多时间,那么一定要好好弄清楚原因。此外,还需要思考的是,怎么做才能吸取经验教训,将来在类似的问题上不再栽跟头?以及,我们采用的方法、使用的工具是否还有可以改进的地方?以及这些bug的影响和严重程度。

<!--[if !supportLists]-->二、        <!--[endif]--> 找到bug,还是修复bug,哪个需要更多时间?

  或许建立一个测试环境、重现问题和测试bug所需的时间,要远远多于找到bug和修复bug的时间。不过对于一小部分显而易见的bug,找到它们很简单——不过修复起来可能就不尽如人意了。

  在《Making Software》一书中,有一章主要是探讨大部分的软件漏洞的来源Dewayne Perry分析认为,相较于修复,发现bug(包括理解bug和重现bug)所需时间更长。有研究表明,大多数的bug(差不多有3/4)既易于发现又易于修复:5天或许更少(这是基于大规模实时系统通过重量级SDLC、大量审查和测试得出的数据)。但是也有很恶心的bug,即便你可以轻轻松松揪到它,还是还得呕心沥血才能修复好。

发现/修复

修复时间<=5

修复时间>5

能重现问题

72.5%

18.4%

难以重现或根本没法重现

5.9%

3.2%

  所以如果你打赌说你能很快修复bug,大多数情况下你还真没说错。不过当你打赌输了的时候,那么,嘿嘿,就意味着你有大麻烦了,顺便介绍个不错的平台—DevStore,源码下载,第三方服务,很实用。

  所以,下次,boss再问什么时候能修复bug,别再傻乎乎地回答马上就能搞定了。

 

  原文:Fixing a Bug is Like Catching a Fish 翻译:codeceo – 小峰

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/c1782746138/article/details/39927939

智能推荐

ERROR in ./public/index.scss 1:13 Module parse failed: Unexpected token (1:13) You may need an appro_index.module.scss 1:13module parse failed: identif-程序员宅基地

文章浏览阅读1.6k次。出现这个问题主要是因为webspack.config.js那边配置错误。这样子写后面再npm run dev就可以行的通。_index.module.scss 1:13module parse failed: identifier directly after number

Gartner IT领导服务:以数据为核心,以分析为动力_领导问题 it服务-程序员宅基地

文章浏览阅读134次。客户成功案例:WatercareWatercare在数字化转型过程中以客户和员工体验为重点,提高业务敏捷性,优化业务流程并提高效率,以及改善有关客户体验和资产生命周期的管理洞察。关键任务技术发展突飞猛进,完全改变了公用事业服务供应商的业务经营、管理资产、与客户互动和激励员工的方法。Watercare开展了一项以人为本(包括其员工和客户)的大型战略性转型加速工作,以实现技术、流程和数据方面的变革,从而更好地预测和满足客户需求。关键挑战包括:功能性重点vs协作性重点技术过时数据分布在许多不同的_领导问题 it服务

程序员跳槽刷题必备神器!不用打开浏览器,就能刷LeetCode-程序员宅基地

文章浏览阅读420次。来自:开源最前线(ID:OpenSourceTop)项目介绍来自:https://github.com/jdneo/vscode-leetcode元宵节过后,春节也算过完..._it跳槽必刷软件

聚类算法——Kmeans算法的学习_testdata/4k2_far.txt数据-程序员宅基地

文章浏览阅读1.4k次。本文记录了我对kmeans算法的学习,kmeans算是聚类算法最简答的一种,哈哈,这是我接触到的第一个算法,由于刚开始学习python,对python的语法不是很了解,不能熟练的运用python编程,代码写的不是很精简,望见谅!原理参考了JerryLead的博客,这个博客是把斯坦福大学的Andrew Ng的讲义翻译了一遍,不过翻译的不错!值得学习!有兴趣的同学还可以看下《模式识别与机器学习》这本书..._testdata/4k2_far.txt数据

http://mybatis.org/dtd/mybatis-3-mapper.dtd 报红_mybatis-3-mapper.dtd爆红-程序员宅基地

文章浏览阅读8.4k次,点赞20次,收藏20次。发生如下爆红情况:解决方案如下:点击OK应用即可_mybatis-3-mapper.dtd爆红

Vue3.0使用vuex_vue3支持vuex3-程序员宅基地

文章浏览阅读196次。vuex3.0是在vue2.x上使用的,不支持vue3.0index.js在main.js同级目录新建文件夹store, 在里面新建文件index,js输入:import { createStore } from 'vuex'export const store = createStore({ state () { return { count: 1 } }})state就是想要管理的全局变量main.jsimport { createApp } f_vue3支持vuex3

随便推点

Jackson: JSON parse error: Cannot deserialize value of type ***-程序员宅基地

文章浏览阅读3.9k次。Jackson: JSON parse error: Cannot deserialize value of type ***我遇到的问题是无法初始化一个对应的对象实例导致的这个问题,添加对应类的无参构造函数以及有参构造函数即可。我的序列化对象为如下所示:import com.fasterxml.jackson.annotation.JsonProperty;import lombok.*;@Data@NoArgsConstructor(access = AccessLevel.PUBLIC)_json parse error: cannot deserialize value of type `com.alibaba.fastjson.jso

extjs4.2主题在线制作_extjs4.2 主题-程序员宅基地

文章浏览阅读724次。http://www.themeext.com/_extjs4.2 主题

由于多次初始化,导致Hadoop集群jps命令缺少DataNode解决方案_重复初始化了jps节点问题-程序员宅基地

文章浏览阅读554次。hadoop集群由于多次初始化导致所有集群缺少DataNode解决方法原因:解决命令:cd /opt/bigdata/hadoop/hadoop260/dfs/rm -rf data/然后 启动hadoop就解决了_重复初始化了jps节点问题

java spring context_Spring-Context的注解实现依赖注入功能-程序员宅基地

文章浏览阅读598次。使用Spring-Context的注解实现依赖注入功能.Demo要点:本例子中主要使用Annotation功能来实现对MoviceService的注入。我们将Cinema.java的头部标注为@Component说明该类交由Spring托管。而Cinema.java中的属性MoviceService标注为@Autowired,则Spring在初始化Cinema类时会从Application Con..._spring注解com.cinema示例

HTML背景图片和背景渐变_html 背景图渐变-程序员宅基地

文章浏览阅读2.3k次。线性渐变盒子的background-image属性可以用linear-gradient()形式创建线性渐变背景background-image: linear-gradient(to right, blue, red);渐变方向也可以写成度数background-image: linear-gradient(45deg, blue, red);可以有多个颜色值,并且可以用百分数定义它们出现的位置linear-gradient(to bottom, blue, yellow 20%, red)_html 背景图渐变

【车载以太网】【AVB/TSN】IEEE802.1Qat 流预留协议-程序员宅基地

文章浏览阅读2.3k次,点赞5次,收藏8次。目录一、概述二、AVB网络设备三、预留四、注册五、信令处理流程:一、概述传统 IEEE 802 网络标准无法将普通TCP异步流量与时间敏感的流媒体流量进行优先级划分。而IEEE 802.1 Qat 流预留协议SRP确保了AV流设备间端到端的带宽可用性。如果所需的路径带宽可用,整个路径上的所有设备(包括交换机和终端设备)将会对此资源锁定(预留+注册)。二、AVB网络设备AVB网络中定义了三类设备:Talker、Bridge、Listener三、预留Talker 节点_802.1qat

推荐文章

热门文章

相关标签