首页 > 代码库 > eclipse调试java程序的九个技巧

eclipse调试java程序的九个技巧

转:http://www.cnblogs.com/lingiu/p/3802391.html

 

九个技巧:

  1. 逻辑结构
  2. 条件debug
  3. 异常断点
  4. 单步过滤
  5. 跳到帧
  6. Inspect
  7. expressions
  8. display
  9. 远程debug

 

  最早开始用eclipse的debug的时候,只会F5 F6 F7 F8,甚至F7都不是很搞的明白是怎么用的,那时候资浅,碰不到需要复杂debug的代码,慢慢工作深入了,场景碰多了,就需要各种debug技巧来提升定位bug效率,以前找人帮忙排查问题,看他开各种窗口debug各种溜甚是羡慕嫉妒恨,慢慢久病成医自己也用溜了eclipse的一些主要的debug技巧。稍作整理分享出来。

  F5678这四个基本技能就略过不说了,但是最基本的技能能解决90%问题,所以虽然略过不说 ,但是必须用的很溜,相信园友达人们这四个肯定比我用的溜的多。

1. 逻辑结构

逻辑结构主要用来展示map之类的collection数据结构存储的值的,它只展示存储值的逻辑部分,而屏蔽了数据结构详细的内部结构,更方便我们查看map之类collection结构里存储的值,推荐使用。

这个按钮就是展示逻辑结构的按钮,下面两个图,上图是不展示逻辑结构,下图是展示逻辑结构,很明显,下图的结构可读性更强,可以专注于debug的变量。

<iframe id="iframe_0.8565363661889365" src="https://www.cnblogs.com/show-blocking-image.aspx?url=http%3A%2F%2Fcavdar.net%2Fuploads%2F2008%2F09%2Flogical_structure_02.gif&maxWidth=919&origin=http://www.cnblogs.com&iframeId=iframe_0.8565363661889365" frameborder="0" scrolling="no" width="520" height="253"></iframe>

<iframe id="iframe_0.4533276477547168" src="https://www.cnblogs.com/show-blocking-image.aspx?url=http%3A%2F%2Fcavdar.net%2Fuploads%2F2008%2F09%2Flogical_structure_03.gif&maxWidth=919&origin=http://www.cnblogs.com&iframeId=iframe_0.4533276477547168" frameborder="0" scrolling="no" width="518" height="145"></iframe>

 

2. 条件debug

条件debug用在需要满足某种条件才会触发断点的场景,比如只有id是12345这条记录会有问题,那就当id等于12345时才触发断点,其他都放过。

右击断点选择断点属性,就能看到这样一个配置框,右边的文本区块可以填写条件代码,比如id==12345,由于每次都要做这个判断,如果循环数很大的话,还是有点点慢的,你可以去上个厕所接个水啊什么的,还是很方便的。

<iframe id="iframe_0.01742950926032183" src="https://www.cnblogs.com/show-blocking-image.aspx?url=http%3A%2F%2Fcavdar.net%2Fuploads%2F2008%2F09%2Fconditional_debugging.gif&maxWidth=919&origin=http://www.cnblogs.com&iframeId=iframe_0.01742950926032183" frameborder="0" scrolling="no" width="757" height="543"></iframe>

 

 

3. 异常断点

异常断点只要用在debug某种异常的时候,可以配置当这个异常出现后才触发断点,不需要debug去寻找异常。

点击这个红圈就能弹出异常断点的窗口,会列出你系统里的所有异常类,然后选择需要断点的异常就OK。

<iframe id="iframe_0.5623434782496197" src="https://www.cnblogs.com/show-blocking-image.aspx?url=http%3A%2F%2Fcavdar.net%2Fuploads%2F2008%2F09%2Fexception_breakpoint.gif&maxWidth=919&origin=http://www.cnblogs.com&iframeId=iframe_0.5623434782496197" frameborder="0" scrolling="no" width="727" height="446"></iframe>

 

 

4. 单步过滤

单步过滤的场景是我们在使用F5来跟到某个方法内部的时候,经常会跟到一些我们确定不需要看的方法内部。

this.getTradeDetail(uid, itemStr.subString(0,5))

比如这行代码,想F5进入getTradeDetail内部,会首先执行itemStr.subString方法,会先进入subString方法,而这方法是jdk的String方法,确定没问题,不需要关心,单步过滤就是跳过这些我们想忽略的方法直接到目标方法内部的一种debug技巧。

Window > PreferencesJava > Debug > Step Filtering 设置过滤器, 可以选择需要过滤掉的包和类。同时要确保你在debug视图中启用了单步过滤,如下图。这样在使用单步调试的时候,就会使用到这个过滤功能。

上图是过滤器配置,典型的就是把jdk的一些类和包配置过滤。下图是要在debug时候开启单步过滤,否则不生效。

<iframe id="iframe_0.15892919090927027" src="https://www.cnblogs.com/show-blocking-image.aspx?url=http%3A%2F%2Fcavdar.net%2Fuploads%2F2008%2F09%2Fstep_filtering_01.gif&maxWidth=919&origin=http://www.cnblogs.com&iframeId=iframe_0.15892919090927027" frameborder="0" scrolling="no" width="711" height="522"></iframe>

 

<iframe id="iframe_0.65265862135678" src="https://www.cnblogs.com/show-blocking-image.aspx?url=http%3A%2F%2Fcavdar.net%2Fuploads%2F2008%2F09%2Fstep_filtering_02.gif&maxWidth=919&origin=http://www.cnblogs.com&iframeId=iframe_0.65265862135678" frameborder="0" scrolling="no" width="707" height="55"></iframe>

 

 

 

5. 跳到帧

跳到帧是一种重入技巧,在debug时,eclipse可以直接跳到调用栈中指定的任意桢,并且使JVM在此处重新运行。这使你可以重新运行你的部分代码,而不需要为了调试之前的代码而重新来一次。

要注意的是:已经被修改的变量不会被重置,它们会保留当时的值。

使用方式:选择调用栈中的一桢,点击按钮“跳到桢”

<iframe id="iframe_0.07913790463755732" src="https://www.cnblogs.com/show-blocking-image.aspx?url=http%3A%2F%2Fwww.vogella.de%2Farticles%2FEclipseDebugging%2Fimages%2Fdroptoframe10.png&maxWidth=919&origin=http://www.cnblogs.com&iframeId=iframe_0.07913790463755732" frameborder="0" scrolling="no" width="729" height="474"></iframe>

6. Inspect

inspect用来查看某个表达式的之,对于变量值debug很容查看,但是对于一个表达式的值就不容易查看,还是这句:

this.getTradeDetail(uid, itemStr.subString(0,5))

想看getTradeDetail的值,就没法想看变量值一样(虽然这个很有可能是赋值给一个变量...),要看这种表达式值,就需要inspect,具体做法是选中这行表达式,然后右击->inspect,或者更方便的快捷键组合:ctrl+shift+i,会弹出如下的展示表达式结果的框:

<iframe id="iframe_0.13562820078258797" src="https://www.cnblogs.com/show-blocking-image.aspx?url=http%3A%2F%2Fcavdar.net%2Fuploads%2F2008%2F09%2Fexpression_evaluation_01.gif&maxWidth=919&origin=http://www.cnblogs.com&iframeId=iframe_0.13562820078258797" frameborder="0" scrolling="no" width="739" height="224"></iframe>

7. expressions

expressions窗口也是用来看变量或者表达式的值的,在windows->show viewz中打开expression窗口,然后在里面添加你想观察的表达式,比如还是这句:

this.getTradeDetail(uid, itemStr.subString(0,5))

然后debug的时候,就能看到被添加的表达式结果了,另外也能根据需要改value的值。

8. display

display也是用来观察和修改变量or表达式的,这个应该用的人比较多,在windows->show viewz中打开display窗口,可以在display窗口里写表达式,然后右击选择display运行查看结果或者ctrl+shift+D快捷键组合,表达式可以是程序中一行代码或者你自己写的一个赋值语句来改变变量值之类的。

<iframe id="iframe_0.26917448827009705" src="https://www.cnblogs.com/show-blocking-image.aspx?url=http%3A%2F%2Fcavdar.net%2Fuploads%2F2008%2F09%2Fexpression_evaluation_02.gif&maxWidth=919&origin=http://www.cnblogs.com&iframeId=iframe_0.26917448827009705" frameborder="0" scrolling="no" width="768" height="139"></iframe>

 

9. 远程debug

远程debug可以用来调试远程服务器上的代码,保证你本地代码和远程部署的代码是一致,就可以通过这种方式debug服务器代码,这个是java web开发的一大利器,否则定位服务器问题简直是灾难。

远程debug需要服务器端启动jvm的时候做一些开启和端口的配置,具体的配置网上很多,搜一下即可。然后在本地的debug configuration中双击添加一个remote java application,填写远程主机的host和配置的debug端口,就可以开始debug了,如下图:

<iframe id="iframe_0.9522710669161654" src="https://www.cnblogs.com/show-blocking-image.aspx?url=http%3A%2F%2Fdl.iteye.com%2Fupload%2Fattachment%2F0062%2F8266%2Ffb13f7aa-53c8-3e48-952b-7e2d01a199fe.gif&maxWidth=919&origin=http://www.cnblogs.com&iframeId=iframe_0.9522710669161654" frameborder="0" scrolling="no" width="774" height="441"></iframe>

 

eclipse调试java程序的九个技巧