分类: Java
2011-11-21 11:33:32
为了准备调试,你需要在代码中设置一个断点先,以便让调试器暂停执行允许你调试,否则,程序会从头执行到尾,你就没有机会调试了。为了设置一个断点,在编辑器左边灰色边缘双击,这里将say()函数位置设置为断点,此时将会显示一个蓝色的小点,表示一个活动的断点。
在调试器下运行程序和运行它非常类似,Eclipse提供了两个选项:选择“使用全方位服务运行调试”菜单使用一个快捷配置,如果默认选项正确,也可以选择“运行以...调试Java应用程序”。在这里我们使用后者。
确保编辑器中的HelloWorld代码被全部选中了,然后从主菜单中选择“运行以...调试Java应用程序”,Eclipse将会启动程序,切换到调试透视图,在断点暂停执行,如下图所示。
调试透视图包括多个新的视图,都是用于调试使用的,首先,在左上方是调试视图(不要和调试透视图混淆了),它显示了所有调用堆和当前所有线程的状态,包括所有已经执行完毕的线程,程序运行到断点位置时,状态显示为暂停。
单步调试代码
调试视图的标题栏是一个让你可以控制Java程序执行的工具栏,前面几个按钮和电子设备,如CD播放器的控制按钮风格非常类似,允许你暂停、继续和终止程序,这些按钮让你可以一行一步地执行程序代码,鼠标移动到每个按钮上时都会显示按钮提示信息,如跟踪,单步,返回等。
如第二个按钮跟踪,当前执行的程序代码在编辑器中处于高亮状态:调用say()函数。如果跟踪的话就会进入这个函数内部,点击跟踪后,高亮的行是首先执行的行 — for语句。
一般情况下,你只想跟踪你自己写的类,对于标准类和第三方类通常没有什么问题,是不需要跟踪的,这时候可以使用过滤后跟踪功能,即Step With Filters,选择Window.Preferences.Java.Debug.Step过滤器,然后选择列出的包和类,多花点时间设置过滤器可以有效减轻调试难度,当你使用普通的跟踪调试功能时经常会遇到许多未知错误,这时使用过滤跟踪就能很好解决这一问题。
评估变量和表达式
调试视图的右边是一个标签视窗包含视图,在这里你可以检查和修改变量和断点,选择变量标签页,这个视图显示了当前范围的变量及其值,在进入for循环之前,这个视图仅包括say()函数的msg参数及其值,单机单步或跟踪按钮进入for循环,变量视图将会显示循环标志i及其值0。
有时一个Java程序有许多变量,但你仅对其中一个或几个感兴趣,为了监视选择的变量和表达式,你可以将它们添加到表达式视图中的监视列表中,例如,选择一个变量i(在编辑器中双击它),点击右键,从弹出的右键菜单中选择监视,这个变量(及其值)就会显示在表达式视图中。
监视变量的一个好处是你可以检查对象和它们的值的详细信息,并且可以修改它们的值。返回到变量视图,展开msg变量显示它的属性,它是一个char数组,展开msg字符串可以显示它的值,例如,双击H,会提示你输入一个新值,如J。
在同一个标签视窗中的是显示视图,它允许你输入任何允许的变量或包括这些变量的实例表达式,选择显示视图然后输入:
msg.charAt(i)
为了快速评估这个表达式,你必须先选中它,然后点击第二个显示视图工具按钮(显示所选文本评估结果),它在显示视图中显示结果,通常最好点击第一个工具按钮(检查所选文本评估结果),因为它添加表达式到表达式视图中,不管使用哪种方法,当表达式中的变量发生变化时,显示的值都不回自动更新。但在表达式视图中,你可以讲表达式转为监视表达式,当你单步调试代码时就会自动更新,切换到表达式视图,注意检查按钮显示下一个表达式,点击表达式然后从弹出的上下文菜单中选择转换成监视表达式,下一个表达式图标将会变成监视图标。
我们还是回到单步调试代码中,你前面在调用System.out.println()时留下了游标,如果你想查看System.out.println()的代码,你可以点击跟踪,否则就点击单步执行System.out.println()函数,开始下一个for循环。
在编辑器下方是连一个标签视窗,包括控制台视图,程序输出就显示在这里,如果你象前面说的那样将H改为J了,那这里将会显示Jello, world!。你也可以点击单步执行,直到循环终止,如果你觉得这个过程太过冗长,也可以点击返回快速结束say()函数返回到main()函数,或者点击继续按钮让Java程序运行到终点。
小结
Eclipse最有用的特性之一就是它集成的调试器,它可以交互式执行代码,通过设置断点,逐行执行代码,检查变量和表达式的值等功能反应其强大的功能,它是一款检查和修复Java程序代码问题的不可替代的工具。