<读书笔记>软件调试之道 :问题的核心-如何修复缺陷
声明:本文档的内容主要来源于书籍《软件调试修炼之道》作者Paul Butcher,属于读书笔记。欢迎转载!
修复缺陷
对于一个好的修复来说,不仅仅是让软件运行正确,还需要为将来奠定基础。一些列零散的未经仔细考虑的修改,都将是原本的简洁设计逐步消失。
好的修复必须同时实现以下目标:
- 修复问题
- 避免引入回归
- 维持或者提高代码的整体质量
-----------需要参考的规则如下----------
1、清除障碍
- 确保一切从头开始,当你不舍得抛弃诊断阶段所做的修改时,利用源码控制系统。
- 需要对所做的修改进行快速审核,不要跳过这一步!
- 随时做记录,或者保留相关文件的副本。
2、测试
- 如果开发过程包括测试优先(测试驱动)开发,因此你拥有一个自动化测试框架和大量的单元测试工具,修改源码时,这种方法在避免引入回归方面能够收到良好的效果。
- 运行现有的测试程序,并证明它们能够通过
- 添加一个或者多个新的测试程序,后者修复现有的测试程序
- 修复缺陷证明你的修复起了作用(以前的失败不再出现)
- 证明没有引入任何回归(以前通过的测试现在都没有失败)
3、修复问题产生的原因而非修复现象
实际工作中,非常时期,一边是客户愤怒的大声叫嚷,一边是项目经理不耐烦的脸色,你可能就迫于压力只是让缺陷消失,然后进行下一个任务;或者是因为你分析的远远不够,也会导致仅仅修复现象,而非原因。无论这么做多么不好,起码你了解根本原因,并且采取了一个“明智”的办法迅速解决了问题。但是这个办法只是修复缺陷的三个目标之一,后两者更加重要。此时要发挥学术真诚的精神,如果不能确信自己真正理解了问题的症结,就不要相信你的修复!
4、重构
最近几年,随着敏捷开发方法的日益普及,最显著的两项技术的广泛应用就是自动化测试和重构技术。 重构是改善既有代码设计而不改变其行为的过程,具体参考《重构:改善既有代码的设计》。
修复缺陷往往不涉及重构,但是如果缺乏经验的话,为修改缺陷而做出的必要修改时会产生重复,这是不该有的,这就是《程序员修炼之道》一书中描述的“不要重复你自己”的原则。
在修复缺陷之后重构比先重构再修复更合理,当然,如果修复工作很复杂,可能要反复经历修复和重构的过程!
切记:重构的同时不可改动代码功能,同样也不能修复缺陷!
5、签入
要合理利用源码控制系统,如果将很多错误集合起来一起签入,就会大大降低其作用
请坚持这项原则:一次逻辑修改只做一次签入
6、代码审查
代码审查没有固定执行时间,有时让同事参与修复的初期阶段,有时只是让其签字确认!该方法是开发过程固有的一部分,而不必看成一个很正式的调试方法!
<读书笔记>软件调试之道 :问题的核心-如何修复缺陷的更多相关文章
- <读书笔记>软件调试之道 :从大局看调试-理想的调试环境
声明:本文档的内容主要来源于书籍<软件调试修炼之道>作者Paul Butcher,属于读书笔记.欢迎转载! ---------------------------------------- ...
- <读书笔记>软件调试之道 :从大局看调试-零容忍策略
声明:本文档的内容主要来源于书籍<软件调试修炼之道>作者Paul Butcher,属于读书笔记.欢迎转载! ---------------------------------------- ...
- <读书笔记>软件调试之道 :从大局看调试-发现代码存在问题
声明:本文档的内容主要来源于书籍<软件调试修炼之道>作者Paul Butcher,属于读书笔记.欢迎转载! ---------------------------------------- ...
- <读书笔记>软件调试之道 :问题的核心-修复后的反思
声明:本文档的内容主要来源于书籍<软件调试修炼之道>作者Paul Butcher,属于读书笔记.欢迎转载! ---------------------------------------- ...
- <读书笔记>软件调试之道 :问题的核心-诊断
声明:本文档的内容主要来源于书籍<软件调试修炼之道>作者Paul Butcher,属于读书笔记. 不要急于动手! 尽管可以利用各种工具和技术以及软件自身查找缺陷,但是你最重要的财富是你的智 ...
- <读书笔记>软件调试之道 :问题的核心-重现问题
声明:本文档的内容主要来源于书籍<软件调试修炼之道>作者Paul Butcher,属于读书笔记. 重现第一,提问第二 问题重现是实证过程的最强大武器,如果不能重现问题,你也无法证明修复了它 ...
- <读书笔记>软件调试之道 :实证方法
有效调试不仅仅是排除缺陷,其包含如下几个步骤 弄明白软件为何运行错误 修复这个问题 避免破坏其它部分 保持或者提高代码的总体质量 确保同样的问题不在其它地方发生,也不会再次发生 构建实验.观察结果 依 ...
- 读书笔记|Windows 调试原理学习|持续更新
关于调试方面的学习笔记,主要来源于<软件调试>的读书笔记和梦织未来论坛的视频教程 1.调试器使用一个死循环监听调试信息. DebugActiveProcess(PID);while(TRU ...
- <读书笔记> 代码整洁之道
概述 1.本文档的内容主要来源于书籍<代码整洁之道>作者Robert C.Martin,属于读书笔记. 2.软件质量,不仅依赖于架构和项目管理,而且与代码质量紧密相关,本书提出一 ...
随机推荐
- 查看哪些表的哪些列含有指定字符串(如‘andy’存在哪些表的哪些列中)
-- 查看表中列含有指定字符.SQL> select * from demo1;NAME ID---------------- ...
- 跨域请求解决方法(JSONP, CORS)
1.跨域 假设我们页面或者应用部署在 http://www.aaa.com 上了,而我们打算从 http://www.bbb.com 请求提取数据.一般情况下,如果我们直接使用 AJAX 来请求将会失 ...
- 在datagrid中实现单击行选择整行
首先添加列:<asp:ButtonColumn Text="选择" CommandName="Select" Visible="False&qu ...
- maven笔记
jar间接依赖: 被依赖的jar的范围要设置成compile,因发布会包含test范围依赖的jar包. 建立项目之间的联系:先在pom中设定依赖关系,然后可以引用了 .conf: C ...
- Python字符串处理
字符串输入: my_string = raw_input("please input a word:") 字符串判断: (1) 判断是不是纯字母 my_string.isalpha ...
- 【MySQL】SQL优化系列之 in与range 查询
首先我们来说下in()这种方式的查询 在<高性能MySQL>里面提及用in这种方式可以有效的替代一定的range查询,提升查询效率,因为在一条索引里面,range字段后面的部分是不生效的. ...
- .pyc是个什么鬼?
1. Python是一门解释型语言? 我初学Python时,听到的关于Python的第一句话就是,Python是一门解释性语言,我就这样一直相信下去,直到发现了*.pyc文件的存在.如果是解释型语言, ...
- sql ROW_NUMBER() 排序函数 (转)
1使用row_number()函数进行编号:如 select email,customerID, ROW_NUMBER() over(order by psd) as rows from QT_Cus ...
- 由system.currentTimeMillis() 获得当前的时间
System类代表系统,系统级的很多属性和控制方法都放置在该类的内部.该类位于java.lang包. currentTimeMillis方法 public static long currentTim ...
- Arduino 翻译系列 - LED 灯闪烁
原文地址 - https://www.arduino.cc/en/Tutorial/Blink 闪烁 这个例子展示了你能拿 Arduino / Genuino 板子来干的最简单的事:使开发板上的 LE ...