Eclipse调试Java的10个技巧

王振威 发布于 2012/09/09 12:06
阅读 76K+
收藏 473

在看这篇文章前,我推荐你看一下Eclipse 快捷键手册,我的eclipse版本是4.2 Juno。

先提三点

  • 不要使用System.out.println作为调试工具
  • 启用所有组件的详细的日志记录级别
  • 使用一个日志分析器来阅读日志
1、条件断点

想象一下我们平时如何添加断点,通常的做法是双击行号的左边。在debug视图中,BreakPoint View将所有断点都列出来,但是我们可以添加一个boolean类型的条件来决定断点是否被跳过。如果条件为真,在断点处程序将停止,否则断点被跳过,程序继续执行。

 

2、异常断点

在断点view中有一个看起来像J!的按钮,我们可以使用它添加一个基于异常的断点,例如我们希望当NullPointerException抛出的时候程序暂停,我们可以这样:

 

3、观察点

这个特性我非常喜欢,他允许当一个选定的属性被访问或者被更改的时候程序执行暂停,并进行debug。最简单的办法是在类中声明成员变量的语句行号左边双击,就可以加入一个观察点。

 

4、查看变量

在选中的变量上使用Ctrl+Shift+d 或者 Ctrl+Shift+i可以查看变量值,另外我们还可以在Expressions View中添加监视。

 

5、改变变量值

我们可以在Debug的时候改变其中变量的值。在Variables View中可以按下图所示操作。



6、在Main方法中停止
在Run/Debug设置中,我们可以按如下图所示的启用这个特性。程序将会在main方法的第一行停住


7、环境变量
我们可以很方便的在Edit Conriguration对话框中添加环境变量


8、Drop to frame
这个功能非常酷,是我第二个非常喜欢的功能,Drop to frame就是说,可以重新跳到当前方法的开始处重新执行,并且所有上下文变量的值也回到那个时候。不一定是当前方法,可以点击当前调用栈中的任何一个frame跳到那里(除了最开始的那个frame)。主要用途是所有变量状态快速恢复到方法开始时候的样子重新执行一遍,即可以一遍又一遍地在那个你关注的上下文中进行多次调试(结合改变变量值等其它功能),而不用重来一遍调试到哪里了。当然,原来执行过程中产生的副作用是不可逆的(比如你往数据库中插入了一条记录)。


9、Step 过滤
当我们在调试的时候摁F5将进入方法的内部,但这有个缺点有的时候可能会进入到一些库的内部(例如JDK),可能并不是我们想要的,我们可以在Preferences中添加一个过滤器,排除指定的包。


10、进入、跳过、返回

其实这个技巧是debug最基本的知识。
  • F5-Step Into:移动到下一步,如果当前的行是一个方法调用,将进入这个方法的第一行。(可以通过第九条来排除)
  • F6-Step Over:移动到下一行。如果当前行有方法调用,这个方法将被执行完毕返回,然后到下一行。
  • F7-Step Return:继续执行当前方法,当当前方法执行完毕的时候,控制将转到当前方法被调用的行。
  • F8-移动到下一个断点处。



OSChina.NET 原创翻译/ 原文链接

加载中
0
实迷途其未远觉今是而昨非
实迷途其未远觉今是而昨非
我觉得eclipse的默认debug界面布局非常不合理
实迷途其未远觉今是而昨非
实迷途其未远觉今是而昨非
回复 @黄华仔 : 现在都用idea了,debug比较符合我的习惯
黄华仔
黄华仔
也是一个需常练的过程吧
0
无名人士
无名人士

不错,确实是原创翻译,之前在另外一个地方也看到过这篇文章

http://www.open-open.com/lib/search?q=Eclipse%B5%F7%CA%D4Java%B5%C410%B8%F6%BC%BC%C7%C9&od=0

黄华仔
黄华仔
so ga
0
fhp0917
fhp0917
这些都不重要,关键是debug的速度,用过idea你就知道什么是好的调试了
0
_大李_
_大李_
很好。。
0
水牛叔叔
水牛叔叔
听说骨灰级的程序大牛才用debug。我不是骨灰及的程序员,所以一直不用debug,只能用用println算了。
小飞侠2009
小飞侠2009
+1
0
小败
小败
这个怎么收藏啊?
0
noday
noday
看来我的debug太肤浅了
0
SevensChan
SevensChan
用debug的时候经常出现神奇的错误。。好像debug本身就有bug似的。。 还是习惯println。。
小飞侠2009
小飞侠2009
我也是愿意用sysout, 今天debug了两小时,最后sysout几分钟就找到问题的源头了
RYAN___
RYAN___
Qweqweqweqwe
返回顶部
顶部