IDEA构建JDK源码阅读的环境以及遇到的问题


背景

直接在项目中查看JDK源码,无法对其加注释,所以需要本地构建

构建

之前用一篇博文中的方式构建一个纯净的JDK源码成功了(https://blog.csdn.net/qq_42191317/article/details/102772497),但是进去之后编译报错(缺包),等一系列的问题,所以最后决定直接从git上clone一个别人构建过的。会在最后附上之前的做法。

我直接从https://github.com/wupeixuan/JDKSourceCode1.8这里clone到本地直接打开用的,但是还是会出现问题(阅读源码的时候,点击进入方法关联到了jdk的源码上自身的源码上),请看下面

如果自己构建会出现什么问题?
首先我遇到的就是:

  • 缺少com.sun.tools包
  • 缺少sun.awt.UNIXToolkit 和 sun.font.FontConfigManager这两个类导致项目报错

这两个,第一个还好,第二个从网上找到这两个class自己手动放到项目对应的文件中,我找了好久找到了,还是报错,真实磨人,所以就放弃了自己构建。

缺少com.sun.tools包

在这里插入图片描述
解决思路:File => Project structure => Libraries 把jdk路径下的lib包添加到工程中,如下图:
在这里插入图片描述

缺少sun.awt.UNIXToolkit 和 sun.font.FontConfigManager这两个类导致项目报错

解决思路: 在src的目录下手动添加这两个类
在这里插入图片描述

阅读源码的时候,点击进入方法关联到了jdk的源码上自身的源码上

在这里插入图片描述
可以看到我看的是AQS类中的某个方法file is readonly,然后发现直接点击进入了jdk的源码,而不是我自己构建的,而这个方法我是从我自己构建的JDK源码点击去的
在这里插入图片描述
这也太难了

参考的博文中也给出了答案,但是没有写完整。
解决思路: 排除掉src.zip文件,按下图操作即可。
在这里插入图片描述
首先声明按照楼主这么做是对的,我们验证一下
在这里插入图片描述
我直接全删掉了,然后添加我自己构建的JDK的SRC目录
在这里插入图片描述
如上图,操作完之后,按照之前点击进入AQS这个类,发现还是进入了JDK本身的源码中,我绝望了,也没有找到好的解决方式。

花了好久好久。。。。。。。
气的我砸键盘,后来发现砸键盘在这个类中居然能打字了,如下图,发现不是file is read only了,可以写了?

在这里插入图片描述
还是不懂,可能是我笨把

会不会是这个类指向这里,但是本身已经不是在这里了?(听不懂把,我也不会表达)

在这里插入图片描述
右键项目copy path,看到绝对路径并不是我说安装的jdk环境中的路径,而是自己构建的代码的路径,即使左侧显示的是在jdk的zip包下面。

所以在这里修改下,然后到我本身构建的JDK目录中查看是否被修改。

在这里插入图片描述

果然,在我刚刚构建的目录中修改成功了,我的设想是对的,而这其中修改了刚刚的sourcePath这个配置,那么我去看一次idea 官方文档怎么说?
在这里插入图片描述
地址:https://www.jetbrains.com/help/idea/2016.3/sdk.html

可能全翻译成中文不太好懂,containing the source code for the SDK binaries included in the classpath set.,这里其中包含类路径集中包含的SDK二进制文件的源代码。,类路径就是
在这里插入图片描述
就是这里,没错,我们java中的源代码大部分就在rt.jar中(题外话),classPath指向这里,但是里面的源代码通过上面的sourcePath已经类似于重定向 到了我自己制定的刚刚构建的位置了。

呜~

嗯,我想是这样的,虽然看起来挺别扭(看着是在jdk的zip中添加注释),不过真的解决问题了(被重定向了),虽然不是很完美,但是够用啦,哈哈哈哈哈哈

其他问题

参考的几个楼主中还有其他的问题,虽然我目前没有debug,但是前几步和他们说的一模一样,所以顺便把他们遇到的问题也记录下来,以后会用到。

debug的时候,误点Alternative source availble for the class xxxx 的disable

在这里插入图片描述
解决思路: 打开setting => Debugger, 如下图 选中该选项。
在这里插入图片描述

编译过程中报java:OutOfMemory,提示系统资源不足

编译过程中报java:OutOfMemory,提示系统资源不足(https://blog.csdn.net/ljj821061514/article/details/52371037)

我的原来默认设置的是700,改成1000就没问题了
在这里插入图片描述

要让代码运行时自动关联到当前项目src目录下的代码(这个跟我说的那个问题一样)

要让代码运行时自动关联到当前项目src目录下的代码(为了不影响平时使用jdk的源码,我创建了一个1.8study,唯一的差别就是把原来的src.zip换成了jdk1.8-sources-study的src目录)(https://blog.csdn.net/u011837804/article/details/80450809)
在这里插入图片描述
原文链接:https://blog.csdn.net/u010999809/article/details/101922489

手动构建(不通过git clone,不推荐)

这种方式有点累,不太推荐,倒不如去github上找优秀的,在巨人肩膀上前行。
这种方式来自:https://blog.csdn.net/qq_42191317/article/details/102772497

简介

在项目开发中,查看jdk源码时是只允许读,无法修改或者加注释的。为了方便学习JDK源码,我们首先需要搭建环境,可以对JDK源码进行修改,添加注释等操作。

Step1:创建项目

打开IDEA,创建一个普通的Java工程,选择好JDK。

Step2:导入源码

由于我们创建项目时选择了JDK8版本,因此会自动配置好代码之间的依赖,我们需要做的就是将源码导入项目。

JDK的源码位于JDK文件夹下的src压缩包里。

打开新建的项目所在目录

将src压缩包解压到项目的src目录下

环境构建完成,接下来便可开始JDK源码阅读之旅!

参考

https://blog.csdn.net/u010999809/article/details/101922489
https://www.jianshu.com/p/c00db010265b
https://blog.csdn.net/u011837804/article/details/80450809
https://blog.csdn.net/qq_42191317/article/details/102772497

发布了548 篇原创文章 · 获赞 3281 · 访问量 258万+

猜你喜欢

转载自blog.csdn.net/dataiyangu/article/details/105011703
今日推荐