修改代码的艺术--YH维护修改“全部退餐”有感
来源:互联网 发布:吉林师范大学网络 编辑:程序博客网 时间:2024/05/21 08:43
2011/1/20上午接到王经理的电话,额,现在来的电话基本上都是YH店出现系统问题了。次数多了,都形成条件反射了。
Bug描述:在前台售单之后,需要退单操作,当输入单号查询出该单所有食物信息后,[全部退餐]功能异常,会提示“未捕获的异常,…. index超出范围….”。
问题解决经过:通过本地测试,发现的确存在这个未捕获的异常,异常存在于该页面的267行代码。查看代码,这一行代码是我改动过的,是我之前为了改正一个”未能正确显示收银员id”的Bug时改动的。
在看代码之前,我分析这种异常一般都是在for循环这类代码执行过程中,在退单功能代码块中,只有两处和退单有关的代码块用到了for循环,经查看,问题就是出现在这里。仔细查看代码,这里边我们需要遍历form窗体中的一个datagridview控件的所有行信息,而就在问题就出现在这里,.rows(i) 和.selectedrows(i) 的不同,我错误的写成了后者。那么,经过了IDE的编译,但运行这部分代码会出现问题。
这是由我修正一个bug而引来了另一个bug的基本情况。昨天看《修改代码的艺术》,里边讲到“当修改一个执行过程代码,则会引进一个bug”。我当时,只是明白这种可能性,并没有过多的感触,那时还在感触,额,这个问题的确可能出现。我应该会注意到的。事实呢,今天就验证了昨天的话,修正了一个bug,又引进了一个bug。我和伟东都意识到,这个问题主要是由于我们的单元测试、集成测试、系统测试,不规范、不完整所导致的。修改代码,重新发布了一个新版本V2.06,便在本地部署调试的时候,主要侧重于退单这部分功能,我们发现根据单号查询出的食物信息表(用datagridview容器承载)中,总会最后留有一个空行,出于潜意识,我选中空行,进行[单个退餐],便又出现了一个bug,”该行对象未有实例…”。额,这里还藏着一个bug….
可能由于客户的一个不小心操作,便会引出这样一个未处理过的bug。
修改代码的艺术,捧着这本艺术,从实践中感悟 修改bug的快乐。
- 修改代码的艺术--YH维护修改“全部退餐”有感
- 修改代码的艺术
- 修改代码的艺术--读后感
- 读书笔记--修改代码的艺术
- 《修改代码的艺术》文摘
- 读《修改代码的艺术》
- 《修改代码的艺术》 读书笔记
- 说说我的YH维护
- 修改wheelView,全部代码
- 代码维护以及修改
- 《修改代码的艺术》 - 书摘精要
- 读书_修改代码的艺术
- 《修改代码的艺术》迷你书
- 《修改代码的艺术》感悟之一
- 《修改代码的艺术》【PDF】下载
- [考试维护]修改代码的感受
- 修改代码的艺术(奋斗的小鸟)_PDF 电子书
- 读书报告之《修改代码的艺术》 (I)
- 文件共享要开启哪个服务?
- 一个java框架的开发日记(4)
- java中的Volatile,transient,native关键字
- apt-get安装的OpenCV库中cvFindChessboardCorners函数的问题
- CStdioFile写文件中出现的问题
- 修改代码的艺术--YH维护修改“全部退餐”有感
- windows下虚拟串口软件VSPD
- linux 驱动开发之内核树构建
- gnucli psk
- Linux中 命令 (备忘)
- brctl
- 移植rp-pppoe到s3c2440(QQ2440v3)实现ADSL拨号上网
- Linux守护进程
- qvfb 安装使用