1. 安装hsids
这一步比较麻烦,需要提前安装cygwin,以及下载openjdk的源码
具体步骤请参考下面的两篇文章
How to build hsdis-amd64.dll and hsdis-i386.dll on Windows
在64位Windows上编译hsdis
编译时还遇到两个小坑
a. 使用最新的binutils-2.29无法编译成功,最后只能下载binutils-2.27的包重新编译
b. make的时候使用-j4参数希望加速编译,结果反而编译失败,只能去掉-j4参数继续单线程编译,比较慢
编译完成后,将/hsdis/build/Linux-amd64里生成的hsdis-amd64.dll文件复制到$JAVA_HOME/jre/bin/server里即可
2. 用hsdis查看JIT后的汇编码
参考这篇文章
使用hsdis查看jit生成的汇编代码
3. 用jitwatch更方便的查看JIT后的汇编码
如果我们使用加-XX:+PrintAssembly参数的方法直接查看JIT后的汇编代码,会得到很多很多的结果,非常难以看懂。
还好有个叫做jitwatch的工具可以帮助我们分析。
安装方法:
a. 去jitwatch的github主页上下载源码,download zip就行了
b. 确定电脑上已经安装了maven3组件,然后在解压后的jitwatch源码目录里执行mvn clean compile exec:java
c. jitwatch的图形界面启动,如下图所示
使用方法:
a. 使用-XX:+UnlockDiagnosticVMOptions -XX:+PrintAssembly -XX:+LogCompilation -XX:LogFile=jit.log 参数启动你的应用程序,然后工作目录下就会产生一个名为jit.log的文件了,里面内容很多,试图人肉分析基本是徒劳的。
b. 运行jitwatch,点击"Open Log"按钮,加载jit.log文件
c. 点击"Config"按钮,设置应用的源码路径和编译后的Class路径,如下图所示:
d. 点击"Start"按钮,然后在左边的树形图里选择自己想要分析的Class,然后右边点击method,就会弹出汇编码分析界面了,如下图所示:
e. 分析界面分为左中右三栏,左边为java源码,中间为java字节码,右边为jit后的汇编码,如果进行过多次jit编译,还能分别查看编译结果,如下图所示:
总之,hsdis+jitwatch用起来还是比较方便的(虽然安装起来确实比较费劲),推荐使用