修改代码的艺术--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的快乐。