寫了那么多年 Java 代碼,終于 debug 到 JVM 了
繼上篇文章 原創(chuàng) | 全網最新最簡單的 OpenJDK13 代碼編譯 之后,我們有了自己編譯后的 jdk 和 hotspot,如下圖所示。接下來就來干一番事情。
搭建調試環(huán)境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 代碼?梢钥吹轿覀兇虻臄帱c生效了,如下圖所示。
恭喜,我們成功調試 JVM 代碼。不過發(fā)現(xiàn)了下面這個異常信息,解決它。
6.發(fā)現(xiàn)這個異常
按 F9 讓程序繼續(xù)跑,我們發(fā)現(xiàn) Console 出現(xiàn)了下面紅框的一行字。
這是 GDB 的異常信息,我們可以通過在我們的用戶目錄下添加配置來解決這個問題。創(chuàng)建 ~/.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 來編譯,然后在程序執(zhí)行參數(shù)那里指定。下面舉個例子。
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.配置啟動參數(shù)
然后在 Clion 程序啟動配置那里指定我們的類 Test。
結果就是我們的程序被運行了。
以上就是我們今天要講的在 JVM 層面上調試我們自己寫的程序。
總結
總結一下搭建這套 JVM 環(huán)境。搭建過程中其實沒有很波折,官方文檔寫的很清晰(雖然都是英文的),這 2 篇文章也是盡最大的努力,把一些步驟簡化,也截圖保留下來,一方面給自己回顧的機會,一方面也是給有想要搭建這套環(huán)境的朋友們一個捷徑。這套環(huán)境接下來的定義是:給自己深入了解 JVM 的機會,在遇到某些知識點不清晰,不明白原理的時候,就可以看一看源碼,揪出源頭的邏輯。
非常建議朋友們搭建這么一套環(huán)境,也不要怕 JVM 里面都是 C/C++ 代碼,可能剛開始看的時候會很費勁,看多了就習慣了。

請輸入評論內容...
請輸入評論/評論長度6~500個字
最新活動更多
-
10月23日火熱報名中>> 2025是德科技創(chuàng)新技術峰會
-
10月23日立即報名>> Works With 開發(fā)者大會深圳站
-
10月24日立即參評>> 【評選】維科杯·OFweek 2025(第十屆)物聯(lián)網行業(yè)年度評選
-
即日-11.25立即下載>>> 費斯托白皮書《柔性:汽車生產未來的關鍵》
-
11月27日立即報名>> 【工程師系列】汽車電子技術在線大會
-
12月18日立即報名>> 【線下會議】OFweek 2025(第十屆)物聯(lián)網產業(yè)大會
- 1 特斯拉工人被故障機器人打成重傷,索賠3.6億
- 2 【行業(yè)深度研究】退居幕后四年后,張一鳴終于把算法公司變成AI公司?
- 3 人形機器人廠商,正在批量復刻宇樹G1
- 4 AI 時代,阿里云想當“安卓” ,那誰是“蘋果”?
- 5 自動駕駛誰將笑傲江湖?如何把握無人駕駛“財富密碼”?
- 6 特斯拉機器人獲得10,000臺訂單?馬斯克抄底成功
- 7 華為公布昇騰芯片三年計劃,自研HBM曝光
- 8 硬剛英偉達!華為發(fā)布全球最強算力超節(jié)點和集群
- 9 機器人9月大事件|3家國產機器人沖刺IPO,行業(yè)交付與融資再創(chuàng)新高!
- 10 谷歌“香蕉”爆火啟示:國產垂類AI的危機還是轉機?