修改代码的艺术--YH维护修改“全部退餐”有感

       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的快乐。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 19
    评论
评论 19
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我是一道光_

1分也是爱,鼓励鼓励

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值