debug是开发者最常用的一种模式,但大多数开发者只会debug自己的代码,而不会debug JDK源码或第三方jar包中的源码。
或许你还没有看源码的必要,或许你通过idea的反编译功能看"死"的源码就足够了,但是当你看不懂源码的时候呢?那么让源码"动"起来,通过断点一步一步地调试源码,观察每一步的数据变化,能更加深刻地了解源码的执行原理。
研究源码是每一位开发者进阶路上的基本功,下面我分别介绍一下JDK源码的debug和第三方源码的debug。本文是基于idea的,eclipse暂时还没研究。
要想debug源码的话,那必须得有源码包,源码包指的是里面都是java文件,而不是编译后的class文件
我们在安装jdk的时候,安装目录下已经自带了源码包,如下图所示
既然源码包已经有了,那么现在要做的事就是,在idea中导入源码包
打开idea的project structure -> SDKs -> Sourcepath视图,可以看到jdk配置好之后,源码包被自动导入进来了。如果没有被自动引入,那么需要点+号手动导入。如下图所示
做好以上事情后,此时还不能debug JDK源码,下面还需要做一步设置
打开idea的settings -> Build,Execution,Deployment -> Debugger -> Stepping视图,在Do not step into the classes下面,取消勾选java.*和javax.*前面的复选框,最后点ok退出即可。如下图所示。
下面就来验证一下,调式String类的subString方法,可以看到断点如约而至进来了,如下图所示
要想调试第三方源码,还是那句话,必须要有源码包,所以只有开源的第三方框架,才能够被断点调试
通过pom.xml引入apache的common-lang3的jar包
org.apache.commons
commons-lang3
3.10
jar包引入之后,common-lang3的jar包是编译后的,而此时是没有源码包的,需要我们另行下载
在idea中找到这个jar包,然后点击Download Sources,如下图所示
等其下载完毕之后,在maven仓库下面,找到对应的文件夹,可以看到多了commons-lang3-3.10-sources.jar这个文件,解压缩之后可以看到里面都是java文件,证实这是个源码包,如下图所示
有了源码包之后,接下来在idea试试效果。可以看到,断点进入了commons-lang3的StringUtils类的isBlank方法里面,如下图所示。
idea中debug JDK源码和第三方源码的入门介绍就讲到这里了,像Spring框架之类的源码博大精髓,往往就算断点调试成功了,也很难在很短的时间内"搞定"源码,需要花时间研究,当然,这对我本人而言也是如此
反正有了debug源码的基础就好说,而且在idea这样一款优秀的软件中,有很多debug技巧满足大家的各种需求。所以,还不会debug源码的小伙伴们,赶紧动手练习吧