openjdk导入idea_JVM | Clion导入OpenJDK11源码并调试

读书要注意的点

1. 《HotSpot实战》是基于JDK7的源码,所以启动类的位置稍有些不一样

2. 《深入理解java虚拟机》中推荐的CmakeList.txt的github地址,是针对于Windows而言,linux和mac 不太适用. 昨天改了半天还改成功, 但是其中的写法可以学习参考

导入源码到CLION

打开CLION -> New CMake Project from Sources

然后选择JDK源码目录,然后按默认勾选,点OK,如下图所示:

调整CMakeList.txt

如果直接按默认的CMakeList.txt来, 会发现任意打开一个代码, 都是全面飘红.

保留下来的CMakeList.txt 主要有两部分:

一.include_directories

这个是为了构建代码索引, 在Clion中看起来不是全面飘红

二.add_executable

这个是为了能在Clion中创建执行程序, 可以直接执行我们的java程序

然后原有的test目录都删除掉

完整的CMakeList.txt因为大长,就不复制,可前进github查看:

https://github.com/xiaodaojava/openjkd11-CmakeList

开始调试

在右上角,和idea一样的位置,创建一个Cmake Application

然后我们把断点打到jdk11/src/java.base/share/native/libjli/java.c394行

如下图所示:

然后点击debug运行:

可以看到进入断点,并且在Debug面板可以看到我们传入的-version参数

在调试过程中,会遇到error: No current target; cannot handle signals until you have a valid target and process.这个错, 先不管, 直接继续运行

最终会在控制台看到如下输出:

LLDB的Signal: SIGSEGV (signal SIGSEGV)

解决上面出现的LLDB异常暂停的错误,需要我们在入口断点处也就是进入到394行时就输入如下命令

process handle --pass true --stop false SIGSEGVprocess handle --pass true --stop false SIGBUS

如下图所示:

然后放过断点继续运行,可以看到, 这次程序没有意外暂停, 而且在控制台输出

总结

开始的调试并不麻烦,也只传了一个-version参数做测试. 后面我们要编写java程序, 并且观察虚拟机是如何执行我们的java代码,大家一起加油!

你可能感兴趣的:(openjdk导入idea)