IDEA&Eclipse中debugger调试常用技巧

Stella981
• 阅读 539

转载请说明出处:IDEA&Eclipse中debugger调试常用技巧

改变变量的值

在调试的过程中可以改变非final变量的值。 IDEA&Eclipse中debugger调试常用技巧

条件断点

有时候断点会打在循环里,或者希望在某个条件下才触发断点,这个时候条件断点就派上用场了,在idea里对着断点右键。 如下,在循环里,希望i的值为8的时候才开始调试。 IDEA&Eclipse中debugger调试常用技巧

代码片段&&变量视图

有时候你调试的时候,突然想增加一段代码,又不想重新启动调试,这个功能可以用上。 IDEA&Eclipse中debugger调试常用技巧 IDEA&Eclipse中debugger调试常用技巧

在调试的过程中同时改变了变量的视图,用toString来显示,可以看到list里的两个值12

Evaluate or Inspect

上面的代码片段使用到的是Evaluate功能,这个功能很强大,比如我在跟踪spring源码的时候,我想知道AOP代理对象如何产生的时候,遇到如下代码: IDEA&Eclipse中debugger调试常用技巧 因为我主要关注代理对象什么时候产生,所以这个时候我只想看看那个方法给我返回了代理对象,这时候我应该直接Step Over还是Step IntoresolveName这个方法里呢?可以用Evaluate来帮忙: IDEA&Eclipse中debugger调试常用技巧 从上图可以看出,我评估了一下这个方法,发现这个方法能返回代理对象,显然我需要Step Into到这个方法里。

Eclipse 如果想在Eclipse里执行evalution或者叫Inspect,有两种方式:

  1. 需要在window -> show view -> display打开display面板,然后在面板里执行(ctrl+u)java语句。 IDEA&Eclipse中debugger调试常用技巧 IDEA&Eclipse中debugger调试常用技巧
  2. 选中语句,右键 -> Inspect(快捷键是Ctrl+Shift+I): IDEA&Eclipse中debugger调试常用技巧

丢弃栈帧(Drop Frame)

大家应该都遇到过调试代码的时候想回到上一步,或者回到上一个调用方法的时候吧?IDE 为我们提供了一个Drop Frame的功能,可以让我们丢弃当前的栈帧,如果不知道这个功能,你可能只能选择重新启动debugger开始调试,这样效率有点低。 假设有这样的调用关系:methodA -> methodB -> methodC -> methodD 如下: 代码调试到第51行,想看看从50进入到methodD内部调试,这个时候就可以使用丢弃栈帧了。在底下调用栈中右键methodC -> Drop Frame,就会回到methodB调用的那一个栈帧。 IDEA&Eclipse中debugger调试常用技巧 IDEA&Eclipse中debugger调试常用技巧

智能步入(Smart Step Into)/步入选择(Step Into Selection)

有时候调试代码的时候会存在层层嵌套的情况,这个时候step into可能就没这么好用了,选择性的step into就显得很重要了。

IDEA IDEA&Eclipse中debugger调试常用技巧

Eclipse Eclipse需要先选中想要Step Into的方法,然后按Ctrl+F5进入,如下: IDEA&Eclipse中debugger调试常用技巧

变量断点

变量断点在变量初始化或者变量值改变的时候可以是程序停在变量值改变的那行代码上。 IDEA&Eclipse中debugger调试常用技巧

当然,变量断点也是可以设置condition的,如上图。

方法断点&&Force step into

方法上也是可以打断点的,比如有时候我们想进入到jdk内部的方法里,因为jdk的class在编译的时候为了节省空间,去掉了调试信息,用普通的step into可能进入不了方法内部,这个时候可以在相应的方法上打个断点,或者使用Force step into进入到方法体内部。 IDEA&Eclipse中debugger调试常用技巧

IDEA&Eclipse中debugger调试常用技巧

多线程调试

idea中让其他线程也在断点中停下来。 IDEA&Eclipse中debugger调试常用技巧 通过Debugger窗口下拉菜单来切换线程: IDEA&Eclipse中debugger调试常用技巧

eclipse中让整个虚拟机都挂起,避免其他线程继续执行。 IDEA&Eclipse中debugger调试常用技巧

日志断点(添加执行语句)

有这样一些场景:需要动态插入一条执行语句,或者调试的时候需要额外打印一些日志信息来协助观察问题。有时候可能会选择在代码里写入一些语句,这样会污染代码而且可能忘记删除或者注释掉,而且通过添加代码的方式可能会导致整个项目重新编译,需要较长时间。 IDEA&Eclipse中debugger调试常用技巧

IDEA&Eclipse中debugger调试常用技巧

IDEA&Eclipse中debugger调试常用技巧 红框部分相当于Log#info出来的信息。 当然你也可以log出堆栈信息,如下,勾选: IDEA&Eclipse中debugger调试常用技巧 甚至你可以添加语句,然后让debug的时候跳过这个断点,不要停留,这样你debug的时候断点到这里就不会挂起: IDEA&Eclipse中debugger调试常用技巧

强制返回(Force Return)

之前在windows上调试hadoop代码的时候,有一段代码要判断可读权限(boolean canRead()),总是返回false导致程序异常而执行中断,然后发现可以在进入某个方法后强制返回,强制返回一个true就不会出错了。 IDEA&Eclipse中debugger调试常用技巧 只要在对应的方法上执行:右键 -> Force Return就可以编写返回语句了。可以编写负责语句,也可以调用方法。 IDEA&Eclipse中debugger调试常用技巧 IDEA&Eclipse中debugger调试常用技巧

本文的录屏软件使用的是ScreenToGif.exe。

未完待续,持续更新。。。

点赞
收藏
评论区
推荐文章
blmius blmius
3年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
待兔 待兔
4个月前
手写Java HashMap源码
HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程HashMap的使用教程22
Jacquelyn38 Jacquelyn38
3年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
Stella981 Stella981
3年前
Android So动态加载 优雅实现与原理分析
背景:漫品Android客户端集成适配转换功能(基于目标识别(So库35M)和人脸识别库(5M)),导致apk体积50M左右,为优化客户端体验,决定实现So文件动态加载.!(https://oscimg.oschina.net/oscnet/00d1ff90e4b34869664fef59e3ec3fdd20b.png)点击上方“蓝字”关注我
Wesley13 Wesley13
3年前
mysql设置时区
mysql设置时区mysql\_query("SETtime\_zone'8:00'")ordie('时区设置失败,请联系管理员!');中国在东8区所以加8方法二:selectcount(user\_id)asdevice,CONVERT\_TZ(FROM\_UNIXTIME(reg\_time),'08:00','0
Wesley13 Wesley13
3年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Stella981 Stella981
3年前
Django中Admin中的一些参数配置
设置在列表中显示的字段,id为django模型默认的主键list_display('id','name','sex','profession','email','qq','phone','status','create_time')设置在列表可编辑字段list_editable
Wesley13 Wesley13
3年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
10个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这