前言
在研究JVM时,想要研究下volatile
关键字的底层实现,需要其对其汇编代码的指令进行观察,故需要查看即时编译器产生的汇编代码。
正文
环境:linux(deepin)
hsdis的配置
- 进入https://sourceforge.net/projects/fcml/files/fcml-1.1.3/,下载源码并解压(这里可能需要科学上网)
- cd fcml-1.1.3
- ./configure && make && sudo make install
- cd example/hsdis && make && sudo make install
- source /etc/profile
- sudo ln -s /usr/local/lib/libhsdis.so <JAVA_HOME>/lib/amd64/hsdis-amd64.so
- sudo ln -s /usr/local/lib/libhsdis.so <JAVA_HOME>/jre/lib/amd64/hsdis-amd64.so
此时随便编写一个java文件Test.java。
- javac Test.java
- java -XX:+UnlockDiagnosticVMOptions -XX:+PrintAssembly Test
成功打印汇编代码信息。
jitwatch工具的使用
以上打印的汇编代码过于杂乱,可以通过jitwatch
工具来提供便利。
- git clone https://github.com/AdoptOpenJDK/jitwatch
- cd jitwatch
- mvn clean
- mvn install
- ./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还得沉下心来慢慢学。