调试

都知道发烧不是因为额头被热水烫过,肚子疼通常也不会是因为肚子受伤.其实调程序也是如此.
找错误的时候不该只从错误的地方区找,有可能在遥远的地方的问题,导致了这里的错误.
也不要去相信那些从来没出过错的地方,就是不会错的,从来不错只表示它过去没错,不表示现在也是对的.

今天一个同事的程序就遇到这个问题,一个自定义表格控件,用了很久了,突然今天发现在一个窗体上操作着操作着就绑不出来数据.
重新进入窗体又可以了,郁闷了很久,单步调试了几个小时(因为不知道怎么重现这个错误,反正就是"某些操作"以后会错),把所有的
代码逻辑都过了好多次,可是就是找不出错在哪,只知道就是在某些地方经过以后,就再也不可能出来数据了.

晚上没辙了,明天要用的,就这个地方过不去,于是扔给我帮忙. 我重复操作几次,掌握到大致的出错地方,然后就在重点区域,如绑定操作
的附近设了断点,运行了几次次,发现代码没有错,Sql语句返回正确,表格绑定方法也没有问题,返回true,就是数据再也不出来.

观察到表格的脚部对数据的条数统计是正确的,只是上面不显示数据. 监视了表格控件的一些主要的属性,意外地发现,表格中表示
当前页索引的属性值是-1,显然这是问题所在,搜索了一下,发现窗体中没有对这个属性赋值的操作.那-1又是怎么来的? 重新进入窗体
属性值出现正确的0,然后做会改变这个值的操作(翻页,在表格组件内部实现) 发现都正常,然后再尝试那些有可能产生错误的操作,
试了好几次,终于有一个地方,操作以后变成了-1,-1以后就永远-1了. 当一个操作导致表格中没有数据的时候,表格的页索引就变成-1
脑海中马上明白发生了什么事了,bug在表格控件内部.  马上也猜出产生这个错误的原因. 原来表格本身保持了这个属性的状态,这样
在多次绑定数据的时候,如果第一次绑定了N页,第二次绑定了M页(N>M+1),并且在第一次绑定以后,翻到了第P页(N>P>M),那么在第2次
绑定的时候这个状态依然是P,而实际上数据却并没有那么多,会抛出NullReferenceException的异常,于是猜测表格控件的设计者考虑到这个情况,
于是,对此做了处理,当遇到这个情况时强制令 P=M-1 (因为一个索引是0开始,一个是1开始,所以-1). 但是他却忽略了同时M=0的情况.
在M=0的时候,P就出现了-1 .由于这个第-1页是没有意义的,也是原控件设计者所没有考虑到的情况. 就发生了上述那些奇怪的总数
统计正常,而数据不显示(因为根本不存在第-1页的数据),由于上面没有数据,又引起了翻页功能的不可用,因此也不可能把这个-1
给修改回来,于是就不管怎么绑数据,怎么操作,都一直-1下去了...

反编译了原控件,从IL中证实了我的猜测完全和实际情况一致. 于是解决问题就变成非常简单了.

另外有一点,控件中对一些异常,有必要throw出来给外面一层,虽然说如果外面没有处理会造成程序崩溃,但是要是把所有没有意料到
的异常都用一个空的catch块把它杀死在控件内部,其实更加危险,造成程序的不可预料性,而且又难以查找.所以这里有一个平衡的问题.
这还是看设计者的经验,具体问题具体分析.

时间: 2024-11-08 21:30:58

调试的相关文章

php异步调试和线上调试网站程序

  下面分享一种方法同时满足这两种条件,既方便网站程序错误调试,又不影响网站的正常运行的调试方法.将下面的php语句复制到公共代码顶部即可.  代码如下   //ini_set('error_reporting',E_ALL ^ E_NOTICE);//显示所有除了notice类型的错误信息 ini_set('error_reporting',E_ALL);//显示所有错误信息 ini_set('display_errors',off);//禁止将错误信息输出到输出端 ini_set('log_

adb-ubuntu真机调试,最后List of devices attached 下什么也没显示

问题描述 ubuntu真机调试,最后List of devices attached 下什么也没显示 按照网上教程ubuntu真机调试,最后List of devices attached 下什么也没显示 $sudo vim /etc/udev/rules.d/51-android.rules 加入以下内容: SUBSYSTEM=="usb", ATTRS{idVendor}=="0bb4", ATTRS{idProduct}=="0cac",M

vs2008-VS搭配QT,x64平台下为挖三维编的dll,怎么调试

问题描述 VS搭配QT,x64平台下为挖三维编的dll,怎么调试 VS搭配QT,x64平台下为挖三维编的dll,怎么调试?新手,试过用挖三维打开调试,但是没看到界面在哪里,请懂得QT的前辈回答,谢谢! 解决方案 https://github.com/Vaa3D/Vaa3D_Wiki/wiki/Build-Vaa3D-on-Linux

PHP100课程学习笔记1--PHP环境搭配和代码调试

1.PHP的优势和背景 PHP是能让你生成动态网页的工具之一.PHP代表:超文本预处理器(PHP: Hypertext Preprocessor). PHP的语法类似于C,Perl,ASP或者JSP. 2.PHP环境的搭配 所需的工具: WampServer 5 集成环境Wamp5是Apache+PHP+Mysql 在Windows下的集成环境,拥有简单的图形和菜单安装.该版本集成了PHP5.2.5 Mysql5 Apache2 phpMyAdmin 2.11.2.1 SQLiteManager

使用lomboz调试JSP

js 前言 凡是有JSP编写经验的人都有JSP调试困难的体会.由于自动化调试工具的缺乏使得在调试JSP时不得不在文件中大量的使用打印语句.这种做法对于定位JSP范围内的错误是一个简单有效的手段,但如何快速有效的定位在JSP中调用的对象的内部错误就显得有点力不从心了.因为这样将不得不频繁地编译.发布.启停服务器,给调试带来极大的不便. 传说中所见即所得的JSP调试工具,就笔者目前掌握的情况来看,并不存在.如果读者有这方面信息的希望告知,呵呵.但是JSP的调试工具却的确存在,而且它是免费的!It's

eclipse/intellij idea 远程调试hadoop 2.6.0

很多hadoop初学者估计都我一样,由于没有足够的机器资源,只能在虚拟机里弄一个linux安装hadoop的伪分布,然后在host机上win7里使用eclipse或Intellj idea来写代码测试,那么问题来了,win7下的eclipse或intellij idea如何远程提交map/reduce任务到远程hadoop,并断点调试? 一.准备工作 1.1 在win7中,找一个目录,解压hadoop-2.6.0,本文中是D:\yangjm\Code\study\hadoop\hadoop-2.

直接调试就可以正常运行,但是直接运行(不调试)就会出现错误

问题描述 我点击调试按钮程序却可以正常运行,但是点击开始执行(不调试)却出现下面的错误今天我在运行C#程序时,遇到了:值不能为空,参数名:path的错误详细信息是:System.ArgumentNullException:值不能为空.参数名:path在System.IO.StreamWriter..ctor(Stringpath,Booleanappend,Encodingencoding,Int32bufferSize)在System.IO.StreamWriter..ctor(Stringp

利用ASP.NET MVC源代码调试你的应用程序

之前写了一篇博客:利用.NET Framework4.0的源代码调试你的应用程序.那篇文章教你如何利用.NET Framework4.0的源代码帮助你调试应用程序,其实也就是进入.NET Framework4.0源代码进行单步调试.由于项目需要,最近学起asp.net mvc.昨天遇到ViewData和TempData他们之间的分别这样让我纠结的问题.有园友强烈建议我去看ASP.NET MVC的源代码.所以,我想到如何在调试ASP.NET MVC程序的时候,有不明白的地方,就单步进入ASP.NE

open-VS 调试运行无法创建文件,直接在debug目录运行源程序时文件正常创建,是怎么回事?

问题描述 VS 调试运行无法创建文件,直接在debug目录运行源程序时文件正常创建,是怎么回事? VS 调试运行无法创建文件,直接在debug目录运行源程序时文件正常创建,是怎么回事? 我该了管理员权限运行VS 然后调试运行 文件还是没有创建,我跟踪了open()函数的返回值 为1 正确的,表明函数调用成功,可是我在debug目录下并没有发现文件啊? 是怎么回事? 解决方案 检查下你创建文件的相对路径是什么.如果你直接给文件名,那么调试的时候试图在program files下创建文件,这是不允许

在MATLAB下调试Caffe

Caffe本身是C++.CUDA语言编写的.在调试模型.参数时,根据运行log.snapshot很难实时反馈当前训练的权值情况,也难以捕捉算法存在的bug. MATLAB则是非常适合算法设计.快速迭代的利器,只需要做少量工作就能编写出复杂的算法,调试非常方便,位于workspace中的变量随时都能打印,无论是一维.二维还是三维数据,都能直观显示,从而有利于定位算法设计问题,减少调试时间. Caffe中有两种Wrapper:Python和MATLAB.Python是开源工具,用户无需付费即可使用,