你真会IDEA的调试功能吗?这4个技巧带你起飞!
前言
上一篇文章 IntelliJ IDEA 高级调试之Stream Trace算是 IntelliJ IDEA 高级调试技巧的开胃菜,很多小伙伴被这个小技巧征服。趁热打铁,今天给大家带来几个我日常工作以及阅读源码必备的 IntelliJ IDEA 高级调试技巧,分分钟要起飞的节奏
断点处添加 log
很多程序员在调试代码时都喜欢 print
一些内容,这样看起来更直观,print 完之后又很容易忘记删除掉这些没用的内容,最终将代码提交到 remote
,code review 时又不得不删减这些内容重新提交,不但增加不必要的工作量,还让 log tree
的一些节点没有任何价值
IntelliJ IDEA 提供 Evaluate and Log at Breakpoints
功能恰巧可以帮助我们解决这个问题, 来看下面代码:
public static void main(String[] args) {ThreadLocalRandom random = ThreadLocalRandom.current();int count = 0;for (int i = 0; i < 5; i++) {if (isInterested(random.nextInt(10))) {count++;}}System.out.printf("Found %d interested values%n", count);}private static boolean isInterested(int i) {return i % 2 == 0;}
假如我们想在第 15 行查看每次调用,随即出来的 i 的值到底是多少,我们没必要在这个地方添加任何 log,在正常加断点的地方使用快捷键 Shift + 鼠标左键
,就会弹出下面的内容
勾选上 Evaluate and log
, 并自定义你想查看的 log/变量,比如这里的 "interested" + i
, 这样以 Debug 模式运行程序(正常模式运行,不会打印这些 log):
interested 7
interested 5
interested 1
interested 2
interested 0
Found 2 interested values
如果你在多处添加了这种断点,简单的看 log 可能偶尔还是不够直观,可以勾选上面图片绿色框线的 "Breakpoint hit" message
:
Breakpoint reached at top.dayarch.TestDebug.isInterested(TestDebug.java:49)
interested 6
Breakpoint reached at top.dayarch.TestDebug.isInterested(TestDebug.java:49)
interested 0
Breakpoint reached at top.dayarch.TestDebug.isInterested(TestDebug.java:49)
interested 9
Breakpoint reached at top.dayarch.TestDebug.isInterested(TestDebug.java:49)
interested 8
Breakpoint reached at top.dayarch.TestDebug.isInterested(TestDebug.java:49)
interested 1
Found 3 interested values
Disconnected from the target VM, address: '127.0.0.1:0', transport: 'socket'Process finished with exit code
如果你想要更详细的信息,那就勾选上 Stack trace
(大家自己查看运行结果吧),有了这个功能,上面说的一些问题都不复存在了
字段断点
如果你阅读源码,你一定会有个困扰,类中的某个字段的值到底是在哪里改变的,你要一点点追踪调用栈,逐步排查,稍不留神,就可能有遗漏
我们可以在 IntelliJ IDEA 中为某个字段添加断点,当字段值有修改时,自动跳到相应方法位置
使用起来很简单:
在字段定义处鼠标左键添加断点(会出现「眼睛」的图标)
在「眼睛」图标上鼠标右键
在弹框中勾选上
Field access
和Field modification
两个选项
如果修改字段值的方法比较多,也可以在 Condition
的地方定义断点进入条件, 有了这个功能的加成,相信你阅读源码会顺畅许多
异常断点
除了阅读源码,一定是遇到了异常我们才开始调试代码,代码在抛出异常之后会自动停止,但是我们希望:
代码停在抛出异常之前,方便我们查看当时的变量信息
这时我们就用到了 Exception Breakpoints
, 当抛出异常时,在 catch 的地方打上断点,可以通过下图的几个位置获取栈顶异常类型,比如这里的 NumberFormatException
知道异常类型后,就可以按照如下步骤添加异常断点了:
然后在弹框中选择 NumberFormatException
重新以 Debug 模式运行程序:
程序「一路绿灯式」定位到抛出异常的位置,同时指出当时的变量信息,三个字:稳,准,狠,还有谁?
方法断点
当阅读源码时,比如 Spring,一个接口的方法可能被多个子类实现,当运行时,需要查看调用栈逐步定位实现类,IDEA 同样支持在接口方法上添加断点(快捷键 cmd+F8
/ctrl+F8
):
鼠标左键在方法处点击断点(♦️形状)
断点上鼠标右键
勾选上绿色框线上的内容,同样可以自定义跳转条件 Condition
当以 Debug 模式运行程序的时候,会自动进入实现类的方法(注意断点形状):
看到这你应该想到常见的 Runnable 接口中的 run 方法了,同样是有作用的,大家可以自行去尝试了
总结
相信有以上四种调试技巧的加成,无论是工作debug 还是私下阅读源码,都可以轻松驾驭了。最后,来看看 IDEA 支持的各种断点调试类型,如果你只知道红色小圆点,那咱在留言区好好说说吧
往期推荐
API 快速开发平台设计思考
惊心动魄的开源项目“政变”,堪比宫斗...
阿里招“AI鉴黄体验官”:日薪1000!网友:钱不钱无所谓,净化互联网人人有责!
这是你想要的工作吗?灵隐寺招聘:没有KPI,佛系上班……
微信新增“炸屎”功能,被好友玩坏了。。
以读侦探小说思维学习技术,让技术变得简单有趣
技术干货,高效工具,实战技巧,珍藏资料,打捞你需要的一切
你真会IDEA的调试功能吗?这4个技巧带你起飞!相关推荐
- Unity3D的断点调试功能
这篇文章介绍的调试工具是Unity自带的MonoDevelop, 假设要用VS,须要下载unityvs http://unityvs.com/. http://liweizhaolili.blo ...
- [转载]eclipse的远程调试功能配置
原文地址:eclipse的远程调试功能配置作者:我的 用途:web应用部署并运行于外部(区别于eclipse环境中启动的)应用服务器中,当出现问题时,可以使用eclipse工程的源代码进行跟踪调试. ...
- VC使用CRT调试功能来检测内存泄漏
信息来源:csdn C/C++ 编程语言的最强大功能之一便是其动态分配和释放内存,但是中国有句古话:"最大的长处也可能成为最大的弱点",那么 C/C++ 应用程序正好印证 ...
- idea调试怎么跳出循环_使用IDEA的Debug调试功能,查看程序的运行过程
Debug追踪,使用IDEA的断点调试功能,查看程序的运行过程 知乎视频www.zhihu.com 1. 在有效代码行,点击行号右边的空白区域,设置断点,程序执行到断点将停止,我们可以手动来运行程序 ...
- VC++ 6.0 中如何使用 CRT 调试功能来检测内存泄漏[转]
/C++ 编程语言的最强大功能之一便是其动态分配和释放内存,但是中国有句古话:"最大的长处也可能成为最大的弱点",那么 C/C++ 应用程序正好印证了这句话.在 C/C++ 应用程 ...
- Dev-C++实现调试功能
程序调试 程序调试是将编制的程序投入实际运行前,用手工或编译程序等方法进行测试,修正语法错误和逻辑错误的过程.这是保证计算机信息系统正确性的必不可少的步骤.编完计算机程序,必须送入计算机中测试.根据测 ...
- Rider EAP17带来了许多改进但缺乏.NET Core调试功能
JetBrains 2月份发布了新版Rider,为.NET开发人员提供了许多IDE插件.本次发布被称为bulid 17,其中有许多新特性首次亮相,包括新的NuGet包管理界面.对崩溃问题的修复以及调试 ...
- 利用浏览器调试功能 计算 百度网盘 文件数量 V2
最近需要统计百度网盘里文件的数量,百度网盘又没有提供这样的功能,因此之前自己写了段脚本进行查验,见<利用浏览器调试功能 计算 百度网盘>.之后发现每个目录最多文件数只有1000,因此研究了 ...
- KDB支持单步调试功能(ARM架构)
0 实践发现KDB不支持step调试功能 (本文针对的是arm CotexA9架构,各种架构的实现方式不一样, X86的好像已经支持,不过本人没有验证过) 1 首先看下要调试的代码段 ...
最新文章
- java的poi导出Excel文件
- Gartner:2020年企业中无“云”战略将极为罕见
- bzoj2132: 圈地计划
- oracle排名怎么去除空值影响,Oracle排序中常用的NULL值处理方法
- 工程师软技能5:生产力
- Android系统(62)-----Android 7.1 新特性之 Shortcuts 介绍
- Oracle数据库用户密码过期
- php ubb类,一个用PHP实现的UBB类!-PHP教程,PHP应用
- [nrf51][nrf52] nrfconnect 安装说明指南
- Apache Kafka(七)- Kafka ElasticSearch Comsumer
- 51单片机模拟I2C读写M24LR04
- 解决通过硬盘或U盘安装ubuntu server出现无法挂载光盘的问题教程
- k8s技术预研8--深入掌握Kubernetes Service
- python爬虫案例分析:爬取肯德基门店地址数据导入csv文件并最终用excel文档呈现
- 生成式对抗网络(GAN)-(Generative Adversarial Networks)算法总结(从原始GAN到....目前)
- 国内9大免费CDN汇总,除了加速乐,你还用过哪些?
- “六如真言”,战必克,攻必取,无往不胜!
- 软件设计师备考(三)——UML(关系和UML图)
- 手机电子邮件用outlook登录
- laravel vs symfony 优缺点
热门文章
- 我们学校的DV作品——《感悟青春》
- 《Ext JS高级程序设计》节选: 一个结合DataWrite和RowEditor的Grid示例(1)
- 第一篇读书笔记,关于UML和模式应用(1)--书籍简介
- httpClient多线程问题
- python 实现ftp服务 简介
- python3报错处理:UnicodeEncodeError: ‘ascii‘ codec can‘t encode characters in position 0-1
- python3 实现 php serialize 函数
- linux ATT汇编 与 Intel汇编 语法格式对比
- linux objdump 反汇编命令
- golang 日期信息和时间戳