linux中查看java汇编代码(hsdis+jitwatch)

前言

在研究JVM时,想要研究下volatile关键字的底层实现,需要其对其汇编代码的指令进行观察,故需要查看即时编译器产生的汇编代码。

正文

环境:linux(deepin)

hsdis的配置

  1. 进入https://sourceforge.net/projects/fcml/files/fcml-1.1.3/,下载源码并解压(这里可能需要科学上网)
  2. cd fcml-1.1.3
  3. ./configure && make && sudo make install
  4. cd example/hsdis && make && sudo make install
  5. source /etc/profile
  6. sudo ln -s /usr/local/lib/libhsdis.so <JAVA_HOME>/lib/amd64/hsdis-amd64.so
  7. sudo ln -s /usr/local/lib/libhsdis.so <JAVA_HOME>/jre/lib/amd64/hsdis-amd64.so

此时随便编写一个java文件Test.java。

  1. javac Test.java
  2. java -XX:+UnlockDiagnosticVMOptions -XX:+PrintAssembly Test
    成功打印汇编代码信息。

jitwatch工具的使用

以上打印的汇编代码过于杂乱,可以通过jitwatch工具来提供便利。

  1. git clone https://github.com/AdoptOpenJDK/jitwatch
  2. cd jitwatch
  3. mvn clean
  4. mvn install
  5. ./launchUI.sh
    此时便可以打开jitwatch工具。

具体查看某个类的汇编代码的步骤如下:
首先,使用 Hsdis 执行代码,输出反汇编内容:

javac Test.java
java -server -XX:+UnlockDiagnosticVMOptions -XX:+TraceClassLoading  -XX:+PrintAssembly -XX:+LogCompilation -XX:LogFile=test.log Test    # Test是java文件类名, test.log 是输出的 log 文件,输出到当前目录下

接着,通过jitwatch工具open log打开日志文件,即可以看到各个方法的汇编代码,关于此工具的更多使用说明可自行搜索。

总结

再次看周志明的《深入理解Java虚拟机》,感觉好接受很多了,JVM还得沉下心来慢慢学。

发布了63 篇原创文章 · 获赞 29 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/Hpsyche/article/details/103688627