这样Debug,排查问题效率大大提升
Debug是开发人员必备的基础技能,伴随着开发生涯,只要需要写代码,就一定有debug的诉求... 因为大部分开发同学都是用Debug来确认程序是不是预期进行(单元测试也可以)。
Debug一个非常常见的我们以为自己已经熟练掌握的技能,有点像说话一样,每个人都可以把话说出来,但不是每个人都能表达出影响力...
大家都会Debug,不过有些Debug的方式可能确实会效率更高一些,还是直接进入主题吧;
开始Debug
相信大家都知道如何开始Debug:
1.在Idea的某个程序文件的目标行旁边,点击一下,设置个小红点。 即断点:
2.使用Debug按钮运行程序,如果程序可以走到断点这里,就开始进入Debug模式。
3.基本操作就是:
- step in 进入方法内部
- step over 直接执行到下一行
- step out 跳出当前的方法
重复1,2,3步骤,刚开始调试的时候主要就是这几个步骤;
下面分享一下一些稍微隐藏一点的调试方法。
断点相关经验
只有满足某些条件才会进入断点
如果说Debug的位置是网关入口,那么流量会很大,各种类型的请求都会走到这个断点里面,如果不能按照条件进入断点,会非常影响我们的效率。
因为进入断点的请求,都不是我们想要的;这个时候可以对断点设置条件,当前请求中必须有满足什么条件才会进入Debug模式。
- 点击程序的目标行旁边,生成一个小红点;
- 右键小红点,可以在condition那里设置程序中的条件;
举个例子,如下当用Debug运行的时候,是不会走到断点的。
而且在设置完成断点条件后,断点旁边会多出一个?和普通的断点不同。
Debug断点只生效一次,同时不阻塞系统
如果说Debug某个正在运行的系统,默认情况下会挂起所有的后续请求,很多人都以为系统死机了... 其实最后发现是你在调试。
有什么办法,可以在调试的时候不阻塞剩余的请求吗?
- 默认只断点一次;
- 断点的时候不挂起整个系统;
如下,通过断点管理器器,进入进来,或者右键断点,然后点击more可以进入进来 设置挂起选项,只挂起当前正在调试的线程,然后再下面勾选一旦命中移除断点。
静态断点,只是想看程序会不会运行到这里来(类似于动态日志)
想确定请求能不能走到某个位置,但是又不想进入debug模式,感觉太重了,能不能如果经过这一行就直接打个日志呢?
这对于有时候程序的一些方法没有打日志,但是又想确认是不是能执行到这里有帮助。
在断点配置里面勾选,命中后打日志,也可以自己加一些其他的输出:
- 不要挂起程序
- 命中处打日志
分组管理断点(系统不同链路的断点)
系统常用的链路主要就几条,而常调试问题的地方也只有几处,可以把这几处位置的断点管理起来,在遇到问题的时候直接把断点分组管理拿出来就可以了。
远程服务器Debug
这里主要是一个配置问题,和本地Debug区别不大,学会配置就好了。 启动程序的时候:
java -Xdebug -Xrunjdwp:transport=dt_socket,server=y,suspend=n,address=0.0.0.0:5005 -jar 待发布的程序jar包名称.jar
在Idea里面:
调试相关经验
程序已经进入断点了,这个时候要查问题了,有一些需要了解的吗。
快速执行到某个位置
有时候我们的断点没有设置在某个位置,但是也不想设置在哪个位置; 在Debug的时候想让程序直接运行到那个位置,怎么处理?
第一种方式: 鼠标移动到对应的行数,然后按下run to cursor按钮:
第二种方式:直接点击文件旁边的数字即可,运行到对应的行哪里
回退重新开始执行
在一些复杂的链路中,方法调用很长,手一抖结果代码又运行了几行,这个时候想去重新开始执行这个断点怎么办?
常规操作是再模拟发出个请求,重新进入断点; 但其实Idea已经提供了对应的方式,直接撤回当前的帧即可,断点会重新进入方法开始执行。
在Frame的位置点击撤回按钮,就会重新进入这个方法开始运行
中断后续执行链路
如果说debug到一半发现可能会往数据库写入脏数据,想直接停止当前的调试,怎么做?
同样在帧的位置,右键,可以提前返回不继续运行,这个提前返回是针对当前的方法的,也可以直接抛出异常;
调试Strem流
Java8之后的labmda表达式里面一般流程会多一点,也不是很好调试,Idea也有对应的工具,可以直接查看Strem流中的数据,在Debug Window下发,如果识别到labmda表达式后会展示出来。
断点的时候运行一些额外代码
在Debug模式下,Idea提供了一个类似于解释器的工具,可以输入一些额外的程序在运行,哪怕和本次debug无关;
当然有个店是这个表达式执行只会返回最后y一行语句的结果。
总结
- debug代码是一个常用而且很常见的技能,但是不是每个人都能很有效率的debug代码...;
- 有一些idea隐藏的debug方式,虽然一些人不关注,但是有用并且能极大提升效率;
- 文章主要介绍一些一些在实际项目中相对有用的可以提升debug能力的一些经验。最后如果说实在是有问题,但是又没办法进入调试模式,可以考虑arthas的trace和watch。
- Spring中实现异步调用的方式有哪些?
- 带参数的全类型 Python 装饰器
- 整理了几个Python正则表达式,拿走就能用!
- SOLID:开闭原则Go代码实战
- React中如何引入CSS呢
- 一个新视角:前端框架们都卷错方向了?
- 编码中的Adapter,不仅是一种设计模式,更是一种架构理念与解决方案
- 手写编程语言-递归函数是如何实现的?
- 一文搞懂模糊匹配:定义、过程与技术
- 新来个阿里 P7,仅花 2 小时,做出一个多线程永动任务,看完直接跪了
- Puzzlescript,一种开发H5益智游戏的引擎
- @Autowired和@Resource到底什么区别,你明白了吗?
- CSS transition 小技巧!如何保留 hover 的状态?
- React如此受欢迎离不开这4个主要原则
- LeCun再炮轰Marcus: 他是心理学家,不是搞AI的
- Java保证线程安全的方式有哪些?
- 19个杀手级 JavaScript 单行代码,让你看起来像专业人士
- Python 的"self"参数是什么?
- 别整一坨 CSS 代码了,试试这几个实用函数
- 再有人问你什么是MVCC,就把这篇文章发给他!