怎么 debug JDK 源码?
点击关注公众号,Java干货及时送达
0. 写在前面
今天给大家分享下如何在搭建一套你自己的 Java 源码学习环境。它有啥用呢?我认为最大的作用就是你可以一边 debug 源代码,情到深处时可以直接写下你当时的一个理解。
![](https://filescdn.proginn.com/f6941f4643ecb15e389e861f5f3110a9/82107b173a1e1cea8cb9f5a3a300a937.webp)
不知道你有没有这种体验,很多时候我们看懂了,总以为自己能记住,结果可能过了两天就忘记了。这也应了那句古话,好记性不如烂笔头。学习 JDK 源码也是一样的道理,比如你心血来潮去研究了下 ArrayList、HashMap、阻塞队列、ConcurrentHashMap、锁等最常用工具类的具体实现,一步步调试后终于顿悟了,这个时候你肯定想把自己的成果写到源码的对应位置,下次再看可就轻松多了。
就算写错了,时隔几年偶然再看时,也能看到当年初出茅庐的那个你的青涩,或许你还会微微一笑,被当年那个挑灯夜战努力的你所触动。
![](https://filescdn.proginn.com/356f67af78df33cc63dff442bb608bfc/487c71f3c3b976005d3ea0181d02601d.webp)
直接去跟源码都是进入到编译后的 *.class
文件的,并不能让你写写画画, 为了可以让你记录自己的成长,留着以后缅怀,七哥今天带你手把手配置一套自己 oracleJDK 17 的源码阅读环境。
配置很简单,跟着一步步操作可以了,具体 JDK 的版本看你自己选择,区别只在于下载时选择不同的 JDK 版本。
工具介绍:
oracleJDK 17
IntellJ IDEA 2021.2
1. 下载JDK,获取源码压缩包
如果你本地已经安装了JDK,并且你就是想搭建已安装JDK版本的源码阅读环境,这里就不用下载了,我今天选择重新下载 oracleJDK17,这是目前最新的长期支持版本,可以用来学习最新的特性嘛。
Mac上查找你本地安装JDK的路径可以使用命令:/usr/libexec/java_home -V
![](https://filescdn.proginn.com/d96f30e3b3241829955aac10cc5c0e01/299d1ff2b26b633a7bccdaebe2ba261b.webp)
下载地址:https://www.oracle.com/java/technologies/downloads/#jdk17-windows
![](https://filescdn.proginn.com/517a2a1ccfeff2fa50fd5b678b76aece/af5e7ab3509cd252528c6c5f86d3d5df.webp)
我们选择 .zip 结尾的免安装版本,下载后直接解压,然后找到解压缩后 lib 目录中的 src.zip
,这个就是我们需要的源码压缩包。你如果已经安装了 JDK,就直接去 JDK 的安装目录下 lib 目录中找到 src.zip ,都是一样的操作。
![](https://filescdn.proginn.com/ae4571e6991a482e722d8b95b8e04bdd/e74fa221156b86f3f2cd01b24628c515.webp)
记着这个位置,后面我们会用到哈😄
最新面试题整理好了,点击Java面试库小程序在线刷题。
2. 创建IDEA项目
在 IDEA 中创建一个简单的 Java 项目,顶部栏 File -> New -> Project…
![](https://filescdn.proginn.com/ba4d780e6ccb760648e56d176fcc1a57/276aae8ad6a3c3a2b15c250f98ef6b84.webp)
创建一个Java空项目,直接 next:
![](https://filescdn.proginn.com/0481fb70c6d8625d92cf6b30e6f74233/e3ed237db1cbcf25fb7a97be6c868201.webp)
名字看你喜欢取就行:
![](https://filescdn.proginn.com/612ccccd9bd4eade8f32eb59a78b0bf8/685a54edcdb79328553d97704b52450a.webp)
3. 解压源码包到IDEA项目中
找到第一步中的 src.zip
源码包,解压到你的项目目录中。我的是在项目的根目录中新建了 jdk17 文件夹,准备将源码解压到这里。
解压完成后的结构如下:
![](https://filescdn.proginn.com/5b38154fd1cc06fe7d29c7b4ed89dbe2/d0bfec621cacce4b3e2d8be0421ccf8e.webp)
到这其实我们就可以查看 *.java
后缀的源代码了:
![](https://filescdn.proginn.com/f7b3f50e19b80a3c0617c74a001ec324/87703262af82675b0c94375fa4c80b52.webp)
但是这样肯定是不够的,我们看源码最重要的还是要靠 debug 调试,现在这样 debug 还是会进入到 jdk 自带的压缩后的源码,这个源码是来自于 src.zip,编辑器中显示是带锁的,无法编辑。
那肯定不行了,别急接下往下看。
最新面试题整理好了,点击Java面试库小程序在线刷题。
4. 配置调试时进入可编辑的源码
通过这一步的配置我们就可以一边调试一边写注释了,每次 debug 进入的都是不断完善写过注释的源码,这种 feel 倍儿爽😁
需要如下几步,我们继续搞起~
IDEA配置调试时允许单步进入
JDK 源码是受保护的,无法直接通过 F7 (step into),可以通过 alt+shift+F7 (force step into),需要我们在 IDEA 中取消以下限制,就可以直接通过 F7 进入源码了。
![](https://filescdn.proginn.com/4973b6863a3f095dfcd0971a0e87ba93/c0520d6f50b22959d21c43966a0cf07c.webp)
设置当前项目关联解压后的源码
既然默认项目调试进入的源码是 JDK 目录下 src.zip 包中的源代码,那么这里我就需要修改下项目关联的 JDK。
点击关注公众号,Java干货及时送达
Project Structure -> SDKs 下 新建SDK:
![](https://filescdn.proginn.com/1c3b787561a1506f52dffa34d25eaf44/24b5e430f5fef3a21c50393087bfe338.webp)
还是先选择我们下载的 JDK17 的 Home 目录:
![](https://filescdn.proginn.com/c4689eb92210db2082db2427d69d4e6d/41dfdd1f31b9c8300c6ec6a14b0fe762.webp)
名字设置为 jdk17-source
(根据你的喜好命名即可)。然后选择 jdk17-source
的 Sourcepath
选项,将源码关联目录删掉。
command+a
全选后删除:
![](https://filescdn.proginn.com/1f309335492e492c20cb5400b50679b9/80585962c218985b718e89ba5a0ab8fa.webp)
然后点击 + 新增,选择我们当前项目中解压后的源码目录:
![](https://filescdn.proginn.com/277c39a5c66e89b1fbe28bc656a7b42f/b37661b2ffe171cc12ba9100e10c24f8.webp)
导入成功后,点击ok即可:
![](https://filescdn.proginn.com/fe184609a052750bbae05d6894b4c6b0/8ef6d421c150c75c7a9a1a796abdcf9a.webp)
然后设置当前项目的 JDK 为我们新增的 jdk17-source
:
![](https://filescdn.proginn.com/713898ea4797f7d31aef4ba13b338024/d95c70d028924bb80d39b45fcae462be.webp)
至此,大功告成!你是否已经迫不及待的想要调试看看啦,我们搞起!
5. debug 调试
此时,我们只需要在 src 目录下写我们的测试代码就好了,打上断点,可劲的钻研吧,少年!
![](https://filescdn.proginn.com/77c100235c48fa27b042388ce5cb23e9/804c65b5bb56de91eb4a96deaf93c47b.webp)
单步调试就会进入到我们解压缩后的源码文件,可以自由的写写画画:
![](https://filescdn.proginn.com/3e39e2b0aa93c24e0fd0443d90eded94/add946eda361b315d6003f1344a624b0.webp)
6. 可能遇到的问题
我按照上面这个步骤搞下来是没有遇到啥问题的,这里记录下可能遇到的问题,一次性搞定肯定是最好的,有报错的可以看看。
编译 OOM
增加IDEA编译所需堆内存,默认700,这里改为1024。
![](https://filescdn.proginn.com/0c967099d7307d8db8223536cd5b71d6/6cb4eb888e005bd97fa7ff1b85720988.webp)
7. 上传到 github
这一步是为了可以让你在家里和公司的电脑上都可以获取到你注释过的源代码,同时在工作中遇到的问题,排查后有新的理解也可以及时同步到远程仓库,方便多端同步维护嘛~
首先在 github 新建一个和本地项目名一致的仓库,然后给本地项目git初始化后关联远程仓库即可。
进入到本地源码项目根目录中依次执行如下命令:
git init
# git remote add 远程仓库名,名称唯一即可 远程仓库地址
git remote add origin https://gitee.com/isevenluo/oracle-jdk17-source-learn.git
# 查看关联的所有的远程仓库名称及地址
git remote -v
# 查看所有的远程仓库名称
git remote
# 提交本地仓库分支(master) 给远程仓库(origin)分支(master) 此处是强制提交
git push origin master -f
# 查看当前未提交的内容,此时应该为空
git status
写在最后
今天给大家分享了如何在本地搭建一套JDK源码的阅读环境,我建议学习Java的同学都配置下,JDK的源码还是要读一读的,对你将会大有益处。加油吧,少年 🤙
![](https://filescdn.proginn.com/e3acb74ed4d9633d70afdecab9c43692/47c0b7cb670f2c6d21753069d92757e4.webp)
![](https://filescdn.proginn.com/3532b4706fdecac52d5808009920de2e/99357069b813dd61462110789d294bf8.webp)
![](https://filescdn.proginn.com/74cfc21581d6d1e57188e43bf94a9f30/b957a5dd3240134980385f35cdce0034.webp)
![](https://filescdn.proginn.com/af7d12710d781979562082494a3702a5/971d12d14c9204696689877a9d50b0fc.webp)
![](https://filescdn.proginn.com/e9296c8189e63b66392d03719c001c05/c9f4163620f7357c7d37e3b8c9bc9be2.webp)
![](https://filescdn.proginn.com/58774425108152bccedf4158697011f3/fa0f089c9ff40bf6dd062b9e0dc4fe8c.webp)
关注Java技术栈看更多干货
![](https://filescdn.proginn.com/9090b1f398ce8c347e423c1631980fc9/c0efb85c2a168aa356e560b70c83175c.webp)