每日一博 | 写了那么多年 Java 代码,终于 debug 到 JVM 了
继上篇文章 全网最新最简单的 OpenJDK13 代码编译 之后,我们有了自己编译后的 jdk 和 hotspot,如下图所示。接下来就来干一番事情。
搭建调试环境
1.下载 CLion 软件
Jetbrains 是一家非常牛逼的公司,咱 Java 里面用到的 IDEA 功能很强大,这公司也为 C/C++ 提供一个 IDE,名叫 CLion,咱需要下载这个 IDE 来调试 JVM 源码。
2.导入源码
安装完 CLion 之后,咱就可以先导入代码,下面简单记录一下操作步骤。
选择 New CMake Project from Sources。
打开我们下载 OpenJDK13 的目录,我的目录是 /opt/java/openjdk/jdk13
。
接下来有弹框点击 Next 就行了,等待导入源码完成(需要几分钟,可以喝杯茶)。
3.启动配置
导完源码后,我们需要配置启动程序,这里有些配置需要重新指定,主要有下面 2 点。
- Executable 修改为咱们编译后的
java
程序。
- Build 需要删除掉。
4.打下断点
我们在 thread.cpp
代码的 Threads::create_vm
方法打下断点。
5.开始 Debug
点击 Debug 按钮,开始调试我们的 JVM 代码。可以看到我们打的断点生效了,如下图所示。
恭喜,我们成功调试 JVM 代码。不过发现了下面这个异常信息,解决它。
6.发现这个异常
按 F9 让程序继续跑,我们发现 Console 出现了下面红框的一行字。
这是 GDB 的异常信息,我们可以通过在我们的用户目录下添加配置来解决这个问题。创建 ~/.gdbinit
文件,添加如下配置。
handle SIGSEGV nostop noprint pass handle SIGBUS nostop noprint pass handle SIGFPE nostop noprint pass handle SIGPIPE nostop noprint pass handle SIGILL nostop noprint pass
再运行就不会有这个异常信息了。
调试自己的代码
上面已经调通了我们编译的 JVM 源码,有同学可能想知道,那要调试自己写的代码得怎么操作呢?我们上面已经看到 Debug 到 JVM 源码了,我们自己的代码则可以通过我们编译后的 JDK 来编译,然后在程序执行参数那里指定。下面举个例子。
1.编写 Test 代码
我们编写一个简单的 Hello JVM 程序,代码如下。
public class Test { public static void main(String[] args) { System.out.println("hello jvm"); } }
2.javac 编译
通过我们编译后的 JDK 命令 javac Test.java 来编译。
liebrother@liebrother:/opt/java/openjdk/jdk13/build/linux-x86_64-server-release/jdk/bin$ ./javac Test.java
3.配置启动参数
然后在 Clion 程序启动配置那里指定我们的类 Test。
结果就是我们的程序被运行了。
以上就是我们今天要讲的在 JVM 层面上调试我们自己写的程序。
总结
总结一下搭建这套 JVM 环境。搭建过程中其实没有很波折,官方文档写的很清晰(虽然都是英文的),这 2 篇文章也是尽最大的努力,把一些步骤简化,也截图保留下来,一方面给自己回顾的机会,一方面也是给有想要搭建这套环境的朋友们一个捷径。这套环境接下来的定义是:给自己深入了解 JVM 的机会,在遇到某些知识点不清晰,不明白原理的时候,就可以看一看源码,揪出源头的逻辑。
非常建议朋友们搭建这么一套环境,也不要怕 JVM 里面都是 C/C++ 代码,可能刚开始看的时候会很费劲,看多了就习惯了。
推荐阅读
了解Java线程优先级,更要知道对应操作系统的优先级,不然会踩坑
后台回复『设计模式』可以获取《一故事一设计模式》电子书
觉得文章有用帮忙转发&点赞,多谢朋友们!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
OSChina 周二乱弹 —— 别戳屏幕!
Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @ 这次装个文艺青年吧 :#今日歌曲推荐# 分享莫西子诗的单曲《把城市拉回乡下喂狗》: 《把城市拉回乡下喂狗》- 莫西子诗 手机党少年们想听歌,请使劲儿戳(这里) @彩票哥暂未上岸 :hr找的都是程序媛来面试 好事啊, 程序媛比较有耐心和爱心, 你问我怎么知道的, 当时我看见的。 “背面我看见了 那正面写的啥让我瞅瞅。” 光看妹子了, 不看代码了, @舌尖滑水 :公司来了一个的妹子,坐在我对面,挺漂亮,影响到我写代码了 再好看的妹子又怎么样? 还能影响你写代码, 你要立场坚定, “再好看的妹子当程序员,该秃的还是会秃的。” 别拿妹子当接口, 也许你不爱写代码是别的原因呢, 比如 @Hork :不爱编程,不爱写代码了。真心话,我上班只是为了吃饭。最近单位让我负责一个子系统,要放在以前我是义无反顾的,现在居然一点意愿都没有了。可能年纪大了,也或许是自己懒惰了吧。 现在给你分配工作, 就是非暴力不合作, 什么事都不想干, 早晨起来上班, 都恨不得让家里的狗送来。 这是年纪大的问题么? 怎么判定? @渣哇 :看一个人岁数就得看他保温杯里是否...
- 下一篇
Apple 回应 Safari 带来的隐私担忧:并未向腾讯发送真实 URL
长期以来,Apple Safari 浏览器的“欺骗性网站警告”功能都依赖于 Google 的安全浏览技术,该功能旨在通过针对安全浏览提供商(如 Google)提供的黑名单服务交叉引用 URL 来增强在线安全性。为使这一功能生效,Apple 必须与 Google 共享一些数据,例如用户的浏览历史记录。 从 iOS 13(也有一说是 iOS 12.2)开始,苹果也开始使用腾讯的安全浏览技术来检查和阻止用户访问欺诈性网站,虽然网址通常会被进行哈希处理,但腾讯依然会在此过程中收到用户 IP 地址的日志。 苹果公司也在“隐私与安全性”条款中清楚地说明:“访问网站之前,Safari 浏览器可能会将从该网站地址计算得出信息发送给‘Google 安全浏览’和‘腾讯安全浏览’,以检查网站是否为欺诈网站”。 “欺骗性网站警告”功能在 Safari 设置中是默认开启的,对数据隐私感到担忧的用户可选择手动关闭: iOS:设置>Safari>关闭欺骗性网站警告 macOS:Safari>首选项>安全>取消选中欺骗性网站警告 不少外媒表示,现在很多人都能接受与 Google 共享自己...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2全家桶,快速入门学习开发网站教程
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- CentOS8安装Docker,最新的服务器搭配容器使用
- Docker安装Oracle12C,快速搭建Oracle学习环境
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- CentOS8,CentOS7,CentOS6编译安装Redis5.0.7
- CentOS7,8上快速安装Gitea,搭建Git服务器
- CentOS关闭SELinux安全模块