关于IDEA:在-IDEA-中的各种调试技巧轻松定位-Bug

201次阅读

共计 5210 个字符,预计需要花费 14 分钟才能阅读完成。

Debug 用来追踪代码的运行流程,通常在程序运行过程中出现异常,启用 Debug 模式能够剖析定位异样产生的地位,以及在运行过程中参数的变动。通常咱们也能够启用 Debug 模式来跟踪代码的运行流程去学习三方框架的源码。

一、Debug 开篇

首先看下 IDEA 中 Debug 模式下的界面。

如下是在 IDEA 中启动 Debug 模式,进入断点后的界面,我这里是 Windows,可能和 Mac 的图标等会有些不一样。就简略说下图中标注的 8 个中央:

  • ① 以 Debug 模式启动服务,右边的一个按钮则是以 Run 模式启动。在开发中,我个别会间接启动 Debug 模式,不便随时调试代码。
  • ② 断点:在右边行号栏单击左键,或者快捷键 Ctrl+F8 打上 / 勾销断点,断点行的色彩可本人去设置。
  • ③ Debug 窗口:拜访申请达到第一个断点后,会主动激活 Debug 窗口。如果没有主动激活,能够去设置里设置,如图 1.2。
  • ④ 调试按钮:一共有 8 个按钮,调试的次要性能就对应着这几个按钮,鼠标悬停在按钮上能够查看对应的快捷键。在菜单栏 Run 里能够找到同样的对应的性能,如图 1.4。
  • ⑤ 服务按钮:能够在这里敞开 / 启动服务,设置断点等。
  • ⑥ 办法调用栈:这里显示了该线程调试所通过的所有办法,勾选右上角的 [Show All Frames] 按钮,就不会显示其它类库的办法了,否则这里会有一大堆的办法。
  • ⑦ Variables:在变量区能够查看以后断点之前的以后办法内的变量。
  • ⑧ Watches:查看变量,能够将 Variables 区中的变量拖到 Watches 中查看

[图 1.1]

[图 1.2]:在设置里勾选 Show debug window on breakpoint,则申请进入到断点后主动激活 Debug 窗口

[图 1.3]:如果你的 IDEA 底部没有显示工具栏或状态栏,能够在 View 里关上,显示出工具栏会不便咱们应用。能够本人去尝试下这四个选项。

[图 1.4]:在菜单栏 Run 里有调试对应的性能,同时能够查看对应的快捷键。

二、根本用法 & 快捷键

Debug 调试的性能次要对应着图一中 4 和 5 两组按钮:

1、首先说第一组按钮,共 8 个按钮,从左到右顺次如下:

[图 2.1]

Show Execution Point (Alt + F10):如果你的光标在其它行或其它页面,点击这个按钮可跳转到以后代码执行的行。

Step Over (F8):步过,一行一行地往下走,如果这一行上有办法不会进入办法。

Step Into (F7):步入,如果以后行有办法,能够进入办法外部,个别用于进入自定义办法内,不会进入官网类库的办法,如第 25 行的 put 办法。

Force Step Into (Alt + Shift + F7):强制步入,能进入任何办法,查看底层源码的时候能够用这个进入官网类库的办法。

Step Out (Shift + F8):步出,从步入的办法内退出到办法调用处,此时办法已执行结束,只是还没有实现赋值。

Drop Frame (默认无):回退断点,前面章节具体阐明。

Run to Cursor (Alt + F9):运行到光标处,你能够将光标定位到你须要查看的那一行,而后应用这个性能,代码会运行至光标行,而不须要打断点。

Evaluate Expression (Alt + F8):计算表达式,前面章节具体阐明。

2、第二组按钮,共 7 个按钮,从上到下顺次如下:

[图 2.2]

Rerun ‘xxxx’:从新运行程序,会敞开服务后重新启动程序。

Update ‘tech’ application (Ctrl + F5):更新程序,个别在你的代码有改变后可执行这个性能。而这个性能对应的操作则是在服务配置里,如图 2.3。

Resume Program (F9):恢复程序,比方,你在第 20 行和 25 行有两个断点,以后运行至第 20 行,按 F9,则运行到下一个断点(即第 25 行),再按 F9,则运行残缺个流程,因为前面曾经没有断点了。

Pause Program:暂停程序,启用 Debug。目前没发现具体用法。

Stop ‘xxx’ (Ctrl + F2):间断按两下,关闭程序。有时候你会发现敞开服务再启动时,报端口被占用,这是因为没齐全敞开服务的起因,你就须要查杀所有 JVM 过程了。

View Breakpoints (Ctrl + Shift + F8):查看所有断点,前面章节会波及到。

Mute Breakpoints:哑的断点,抉择这个后,所有断点变为灰色,断点生效,按 F9 则能够间接运行完程序。再次点击,断点变为红色,无效。如果只想使某一个断点生效,能够在断点上右键勾销 Enabled,如图 2.4,则该行断点生效。

[图 2.3]

更新程序,On ‘Update’ actions,执行更新操作时所做的事件,个别抉择 ’Update classes and resources’,即更新类和资源文件。

个别配合热部署插件会更好用,如 JRebel,这样就不必每次更改代码后还要去重新启动服务。如何激活 JRebel,在最初章节附上。

上面的 On frame deactivation,在 IDEA 窗口失去焦点时触发,即个别你从 idea 切换到浏览器的时候,idea 会主动帮你做的事件,个别能够设置 Do nothing,频繁切换会比拟耗费资源的。
[图 2.4]

三、变量查看

在 Debug 过程中,跟踪查看变量的变动是十分必要的,这里就简略说下 IDEA 中能够查看变量的几个中央,置信大部分人都理解。

1、如下,在 IDEA 中,参数所在行前面会显示以后变量的值。

[图 3.1]

2、光标悬停到参数上,显示以后变量信息。点击关上详情如图 3.3。我个别会应用这种形式,快捷不便。

[图 3.2]

[图 3.3]

3、在 Variables 里查看,这里显示以后办法里的所有变量。

[图 3.4]

4、在 Watches 里,点击 New Watch,输出须要查看的变量。或者能够从 Variables 里拖到 Watche 里查看。

[图 3.5]

如果你发现你没有 Watches,可能在下图所在的中央。

[图 3.6]

[图 3.7]

四、计算表达式

在后面提到的计算表达式如图 4.1 的按钮,Evaluate Expression (Alt + F8)。能够应用这个操作在调试过程中计算某个表达式的值,而不必再去打印信息。

[图 4.1]

1、按 Alt + F8 或按钮,或者,你能够选中某个表达式再 Alt + F8,弹出计算表达式的窗口,如下,回车或点击 Evaluate 计算表达式的值。

这个表达式不仅能够是个别变量或参数,也能够是办法,当你的一行代码中调用了几个办法时,就能够通过这种形式查看查看某个办法的返回值。

[图 4.2]

2、设置变量,在计算表达式的框里,能够扭转变量的值,这样有时候就能很不便咱们去调试各种值的状况了不是。

[图 4.3]

五、智能步入

想想,一行代码里有好几个办法,怎么只抉择某一个办法进入。之前提到过应用 Step Into (Alt + F7) 或者 Force Step Into (Alt + Shift + F7)进入到办法外部,但这两个操作会依据办法调用程序顺次进入,这比拟麻烦。

那么智能步入就很不便了,智能步入,这个性能在 Run 里能够看到,Smart Step Into (Shift + F7),如图 5.1

[图 5.1]

按 Shift + F7,会主动定位到以后断点行,并列出须要进入的办法,如图 5.2,点击办法进入办法外部。

如果只有一个办法,则间接进入,相似 Force Step Into。

[图 5.2]

六、断点条件设置

通过设置断点条件,在满足条件时,才停在断点处,否则间接运行。

通常,当咱们在遍历一个比拟大的汇合或数组时,在循环内设置了一个断点,难道咱们要一个一个去看变量的值?那必定很累,说不定你还错过这个值得从新来一次。

1、在断点上右键间接设置以后断点的条件,如图 6.1,我设置 exist 为 true 时断点才失效。

[图 6.1]

2、点击 View Breakpoints (Ctrl + Shift + F8),查看所有断点。

Java Line Breakpoints 显示了所有的断点,在左边勾选 Condition,设置断点的条件。

勾选 Log message to console,则会将以后断点行输入到控制台,如图 6.3

勾选 Evaluate and log,能够在执行这行代码是计算表达式的值,并将后果输入到控制台。

[图 6.2]

[图 6.3]

3、再说说左边的 Filters 过滤,这些个别状况下不罕用,简略说下意思。

Instance filters:实例过滤,输出实例 ID(如图 6.5 中的实例 ID),然而我这里没有胜利,不晓得什么起因,晓得的敌人留个言。

Class filters:类过滤,依据类名过滤,同样没有胜利 ….

Pass count:用于循环中,如果断点在循环中,能够设置该值,循环多少次后停在断点处,之后的循环都会停在断点处。

[图 6.4]

[图 6.5]

4、异样断点

通过设置异样断点,在程序中呈现须要拦挡的异样时,会主动定位到异样行。

如图 6.6,点击 + 号增加 Java Exception Breakpoints,增加异样断点。而后输出须要断点的异样类,如图 6.7,之后能够在 Java Exception Breakpoints 里看到增加的异样断点。

我这里增加了一个 NullPointerException 异样断点,如图 6.8,呈现空指针异样后,主动定位在空指针异样行。

[图 6.6]

[图 6.7]

[图 6.8]

七、多线程调试

个别状况下咱们调试的时候是在一个线程中的,一步一步往下走。但有时候你会发现在 Debug 的时候,想发动另外一个申请都无奈进行了?

那是因为 IDEA 在 Debug 时默认阻塞级别是 ALL,会阻塞其它线程,只有在以后调试线程走完时才会走其它线程。能够在 View Breakpoints 里抉择 Thread,如图 7.1,而后点击 Make Default 设置为默认选项。

[图 7.1]

切换线程,在图 7.2 中 Frames 的下拉列表里,能够切换以后的线程,如下我这里有两个 Debug 的线程,切换另外一个则进入另一个 Debug 的线程。

[图 7.2]

八、回退断点

在调试的时候,想要从新走一下流程而不必再次发动一个申请?

1、首先意识下这个办法调用栈,如图 8.1,首先申请进入 DemoController 的 insertDemo 办法,而后调用 insert 办法,其它的 invoke 咱们且先不论,最下面的办法是以后断点所在的办法。

[图 8.1]

2、断点回退

所谓的断点回退,其实就是回退到上一个办法调用的开始处,在 IDEA 里测试无奈一行一行地回退或回到到上一个断点处,而是回到上一个办法。

回退的形式有两种,一种是 Drop Frame 按钮(图 8.2),按调用的办法逐渐回退,包含三方类库的其它办法(勾销 Show All Frames 按钮会显示三方类库的办法,如图 8.3)。

第二种形式,在调用栈办法上抉择要回退的办法,右键抉择 Drop Frame(图 8.4),回退到该办法的上一个办法调用处,此时再按 F9(Resume Program),能够看到程序进入到该办法的断点处了。

但有一点须要留神,断点回退只能从新走一下流程,之前的某些参数 / 数据的状态曾经扭转了的是无奈回退到之前的状态的,如对象、汇合、更新了数据库数据等等。

图[8.2]

图[8.3]

图[8.4]

九、中断 Debug

想要在 Debug 的时候,中断请求,不要再走残余的流程了?

有些时候,咱们看到传入的参数有误后,不想走前面的流程了,怎么中断这次申请呢(前面的流程要删除数据库数据呢 ….),难道要敞开服务重新启动程序?嗯,我以前也是这么干的。

确切的说,我也没发现能够间接中断请求的形式(除了敞开服务),但能够通过 Force Return,即强制返回来防止后续的流程,如图 9.1。

点击 Force Return,弹出 Return Value 的窗口,我这个办法的返回类型为 Map,所以,我这里间接返回 results,来强制返回,从而不再进行后续的流程。或者你能够 new HashMap<>()。

[图 9.1]

[图 9.2]

十、附:JRebel 激活

目前自己始终应用 JRebel 做热部署工具,成果还算现实,批改 Java 代码或者 xml 等配置文件都能热更新。偶然服务开久了,或更改的文件较多时,热更新没有失效,须要重新启动服务。

这里只是简略说下我在网上看到的一种收费取得永恒使用权的形式(非破解),不确定这种形式什么时候不能用。

  • ① 首先你须要一个 Facebook 或 Twitter 的账号(最好 Twitter)
  • ② 进入这个网址:https://my.jrebel.com/,并登 …
  • ③ 而后在 Install and Acticate 里能够失去你的永恒激活码。
  • ④ 在设置里 Jrebel 里设置激活码,如图 10.3,如果没有装置 JRebel 插件,先在 Plugins 里装置搜寻装置 JRebel 插件。

[图 10.1]

[图 10.2]

[图 10.3]

有什么不妥之处或者更好的形式,欢送留言!

作者:bojiangzhou
https://www.cnblogs.com/chian…

正文完
 0