欢迎来到天天文库
浏览记录
ID:62506007
大小:261.67 KB
页数:7页
时间:2021-05-10
《如何调试代码.docx》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、我们在做程序开发时,难免会遇到错误异常。如何快速地找到出错的地方、分析错误的原因以及找到解决问题的方案,是许多初级程序员困扰的问题,这也正是经验的宝贵之处。下面我将简单介绍在VisualStudio中调试以及一些高级的调试和常见的错误。PS:如无特别说明VisualStudio均指DevIO即VisualStudio2010。入门篇假设你是有着.Net平台的程序员,并且使用VisualStudio做为开发工具。断点:最简单的一种,设置一个断点,程序执行到那一句就自动中断进入调试状态。设置断点,在你觉
2、得有问题的代码行,左侧单击,会出现红色的红点即断点。prlvoidTaskDialo^(),冶;kPi況i辽0国di箱血刘启动调式:按F5,或者菜单栏---调式---开始调试,或者工具栏的r图标TeamT00Is.METR.eflectorArch吐日yVrndows■kStdrtDebuggingR5EStartWith0utDebuggingCtri+F5A.1^tsrtPerfarmaneeAnalysisAlt+凰AttachtcProcess....Exceptions,-匚tritD,E
3、快速监视:快速查看变量或者表达式的值,也可以自定义表达式进行计算单步执行F11);一种是直接执行当前函数里剩有三种,一种是每次执行一行(F10);一种是每次执行一行,但遇到函数调用就会跳到被调用的函数里(下的指令,返回上一级函数(Shift+F11)还有一种后悔药,设为下一句(SetNextStatement),即下一句会被执行的语句(右击设置或者快捷键:Ctrl+Shift+F10),但要注意在调试与数据有关的时候,设置下一句有可能会报异常。如在调试向DataTable中添加行的时候,已经存在的行
4、不能重复被添加到DataTable中监视调试器可能会自动列出一些相关变量的值,但是你可能还关心其它变量的值,可以添加对这些变量的监视。还可以监视一个表达式的值,比如a+b。但是,这个表达式最好不要修改变量的值,比如监视a++都会导致监视时修改了a的值,影响了程序的运行结果。调试技巧篇使用快捷键会大大提升我们的调试效率,常用的调试快捷键:F5启动调试F10执行下一行代码,但不执行任何函数调用。F11在执行进入函数调用后,逐条语句执行代码。Shift+F11执行当前执行点所处函数的剩余行。Shift+F
5、5停止运行程序中的当前应用程序。可用于“中断”模式和“运行"模式。拖动断点(感谢圣殿骑士的提醒)在调试中,我们可以拖动断点,使得程序运行到我们想要运行的地方。通常是用来验证这段代码对程序的运行结果有没有影响的。因为我们拖动代码,则被过滤的代码就不会执行,将它跟原来的相比,可以看出去掉这段代码有什么影响条件中断假如你写了个for循环,而且循环的次数比较多,如下代码,现在我们知道在i=50的时候会有异常,那我们不可能按50次F5去调试这代码,不然这效率….privatevoidConditionDebu
6、g(){for(inti=0;i<100;i++){if(i==50){//someerrorcodehereConsole.WriteLine("i=50here");}}}我们可以直接利用vs提供的功能修改变量i的值,一开i=0,即刚进入for循环中,我们设置将i改为49并回车,再调试一次,会发现i=50;如下图privat'6voidCondilit>nl)^bu.g0fortinti=0:i7、v);privit*voidCondLtionDrtugOfor(inti-0:it100;i十+)7i49ifComcla.TritaLina(^1=50Mr*");当然我们也可以直接在代码里写代码以达到这个目的,代码如下privatevoidConditionDebug(){for(inti=0;i<100;i++){System.Diagnostics.Debug.Assert(i!=50);if(i==50){//someerrorcodehereConsole.WriteLine("i=58、0here");}}}使用了调试中的Assert(断言),当执行程序后会弹出如下的提示框,点击Ingore(忽略)即可,会发现此时i已经为50了,有兴趣的朋友可以看看Assert的其他用法。ImmediateWindowImmediatewindow在调试的时候计算表达式的值、执行语句、打印变量的值等。我们输入命令(注意一定要以>"开头),会有智能提示,而且命名都是自解释型Immediate?^ndo,v剝LocalsWatch1黑iCaHStack■Immedrat
7、v);privit*voidCondLtionDrtugOfor(inti-0:it100;i十+)7i49ifComcla.TritaLina(^1=50Mr*");当然我们也可以直接在代码里写代码以达到这个目的,代码如下privatevoidConditionDebug(){for(inti=0;i<100;i++){System.Diagnostics.Debug.Assert(i!=50);if(i==50){//someerrorcodehereConsole.WriteLine("i=5
8、0here");}}}使用了调试中的Assert(断言),当执行程序后会弹出如下的提示框,点击Ingore(忽略)即可,会发现此时i已经为50了,有兴趣的朋友可以看看Assert的其他用法。ImmediateWindowImmediatewindow在调试的时候计算表达式的值、执行语句、打印变量的值等。我们输入命令(注意一定要以>"开头),会有智能提示,而且命名都是自解释型Immediate?^ndo,v剝LocalsWatch1黑iCaHStack■Immedrat
此文档下载收益归作者所有