Windows安装HSDIS、JITWatch
JVM的学习很多时候得看着字节码和汇编代码才好理解,所以先下载HSDIS和JITWatch做好准备。
按照教程一步一步的来
https://dropzone.nfshost.com/hsdis/
1、下载Cygwin,傻瓜式安装
2、将这些搜索出来(有个搜索窗口,点击all/devel展开),双击一下skip
gcc-core
make
-
mingw64-i686-gcc-core
(only needed forhsdis-i386.dll
) -
mingw64-x86_64-gcc-core
(only needed forhsdis-amd64.dll
)
3、Download GNU binutils,推荐安装个迅雷插件,感觉比浏览器下的快,虽然也不大,将安装包放到家目录
这就是和Linux命令行一样的,双击运行之后,`pwd`看看家目录在哪(就是你安装Cygwin的路径下,/home/username)
将安装包丢到家目录
4、tar xvf binutils-2.35.1.tar.xz
解压
5、趁着解压的闲工夫,将hsdis给下载下来
最好下一个和自己jdk版本相同的吧,避免后面出问题,可能你会想知道jdk8和jdk8u的区别
6、丢到家目录,解压,然后一直来到hidis文件夹下,注意是找到makefile文件所在的那个文件夹,就是src/share/tools/hsdis/
make OS=Linux MINGW=x86_64-w64-mingw32 BINUTILS=~/binutils-2.35.1
进行编译安装
这里安装可是碰到大坑了,gcc和binutils版本可能不对付,所以选择自己想要的版本怕是搞不了,直接安装人家默认版本吧。就按照步骤来。
7、整到hisdis-amd64.dll之后丢到jre/bin/server目录里就完事了
8、下载JITWatch
9、运行JITWatch
mvn clean compile test exec:java
10、使用JITWatch
-XX:+UnlockDiagnosticVMOptions
-
-Xcomp
以纯编译方式运行,触发JIT -
-XX:+PrintAssembly
反编译 -
-XX:+LogCompilation
保留编译日志,JITWatch要看的就是这个日志 -
-XX:LogFile=jit.log
日志的路径和名字 -
-XX:CompileCommand=compileonly,*VolatileTest.increase
指定只编译的方法,不然你看着短短的代码编译出来一大堆东西,要等很久的
11、打开log文件,指定source文件和classes文件的位置
费了老大功夫,终于看到volatile底层调用的这个lock指令了,这就是解决指令重排序的底层实现。