🕵️♂️ 前言:你还在用“Sout”调试吗?
场景还原:
你写了一个循环 1000 次的代码,第 999 次报错了。
小白做法:在循环里写个System.out.println(i),然后瞪着控制台滚动的几千行日志找问题。
普通做法:打个断点,疯狂按 F9 (Resume),按 999 次直到手抽筋。
大神做法:右键断点 -> 设置Condition: i == 999-> 一键直达。
兄弟们,IDEA 是 JetBrains 公司倾尽全力打造的神器,它的 Debug 功能强到离谱。如果你只会 F7 (Step Into) 和 F8 (Step Over),那你真的亏大了。
今天,我就揭秘 IDEA 里那些能让你早下班 1 小时的高级调试技巧。
🔮 技巧一:条件断点 (Conditional Breakpoint) —— 大海捞针
痛点:
遍历一个List<User>,里面有 1 万个用户,只有名字叫 “Tom” 的那个用户数据有问题。
操作:
- 在代码行打上红点。
- 右键点击那个红点。
- 在弹出的
Condition框里输入:user.getName().equals("Tom")。
效果:
程序会像疯狗一样狂奔,忽略前 9999 个用户,瞬间停在 “Tom” 这一行。
从此告别疯狂按 F9!
⏳ 技巧二:断点回退 (Drop Frame) —— 时光倒流
这是我最喜欢的功能,没有之一!
痛点:
你正在 Debug 一个复杂的方法,一路 F8 (下一步)。
突然!你手一抖,按快了,跳过了最关键的那一行报错代码。
此时你的内心:“完了,要停止服务,重启,重新发请求,重新再来一遍……”
操作:
- 找到 Debug 窗口的Frames(栈帧)面板。
- 找到当前的方法名,右键选择“Drop Frame”(或者点击工具栏上的“向后箭头”图标)。
原理图解:
效果:
你惊奇地发现,代码执行指针回到了当前方法的入口处(或者调用它的上层方法)!所有的局部变量都变回了没执行之前的样子。
你可以重新 F8,再一次小心翼翼地走到那一行。
(注意:Drop Frame 只能回退内存状态,不能回退已经写入数据库的数据哦!)
🖐️ 技巧三:动态改值 (Set Value) —— 上帝之手
痛点:
你正在测试一个if (isVip)的逻辑,但数据库里当前用户的isVip是false。
难道你要去改数据库,改完测完再改回来?太麻烦了!
操作:
- Debug 停在
if (isVip)这一行。 - 在 Variables 面板里找到
isVip变量。 - 右键 -> Set Value(或者按 F2)。
- 直接把它改成
true。
效果:
虽然数据库里还是false,但在当前这一次运行内存中,它变成了true。程序直接走进了if分支。
这一招在模拟异常分支、特定金额计算时,简直是神技。
🌊 技巧四:Stream 调试器 (Trace Current Stream Chain)
痛点:
Java 8 的 Stream 流式编程很爽,但 Debug 起来是火葬场。一行代码里有filter,map,sorted,collect,到底是哪一步把数据弄丢了?
操作:
- 断点打在 Stream 链式调用上。
- 点击 Debug 工具栏上的“Trace Current Stream Chain”图标(看起来像一排扁平的方块)。
效果:
IDEA 会弹出一个可视化窗口,把每一步的数据变化(过滤了谁、转换成了什么)画成图表展示给你看。一目了然!
🧱 技巧五:强制返回 (Force Return) —— 模拟报错
痛点:
A 方法调用 B 方法,你需要测试 B 方法抛异常或返回null时 A 的反应。但 B 方法逻辑很稳,很难报错。
操作:
- Debug 进入 B 方法的第一行。
- 右键 ->Force Return。
- 输入你想要返回的值(比如
null)或者直接抛出异常。
效果:
B 方法后续的代码一行都不会执行,直接给 A 方法扔回去一个null。
这在测试“服务降级”、“熔断处理”时非常有用。
📝 总结
Debug 的能力,决定了你解决 Bug 的效率。
很多时候,资深开发之所以“资深”,不是因为他打字快,而是因为他工具用得溜。
- 想找特定数据?用Condition。
- 手抖错过了?用Drop Frame。
- 数据不对?用Set Value。
别再让满屏的System.out.println污染你的代码了。从今天起,做一个优雅的 Debugger。