使用hsdis查看jit生成的汇编代码
JVM 有 HotSpot引擎可以对热代码路径进行有效的 JIT优化,大幅度提升计算密集代码的性能。默认一个方法至少被调用10k次以上才可能被JIT优化。
查看JIT工作情况
Java代码
- public class VolatileBarrierExample {
- long a;
- volatile long v1=1;
- volatile long v2=1;
- void readAndWrite(){
- long j=v1;
- long i=v2;
- a=i+j;
- v1=i+1;
- long v=v1;
- v2=j*2;
- }
- public static void main(String[] args){
- final VolatileBarrierExample ex=new VolatileBarrierExample();
- for(int i=0;i<50000;i++)
- ex.readAndWrite();
- }
- }
运行命令:
- java -XX:+PrintCompilation VolatileBarrierExample
输出:
- VM option '+PrintCompilation'
- 242 1 VolatileBarrierExample::readAndWrite (40 bytes)
- 249 1 % VolatileBarrierExample::main @ 10 (27 bytes)
用如下命令行可以更多地了解内联优化的实际情况以及优化发生的级别:
- java -XX:+PrintCompilation -XX:+UnlockDiagnosticVMOptions -XX:+PrintInlining -XX:+TieredCompilation VolatileBarrierExample
查看JIT生成的汇编代码
环境说明:
1. CPU:Intel i7
2. 操作系统:Ubuntu 12.04-amd64
3. JDK:openjdkversion "1.7.0-internal-fastdebug",我使用的是fastdebug版本,可以直接使用openjdk。
4. hsdis 下载地址:https://kenai.com/projects/base-hsdis/downloads,也可自行下载源代码编译,将hsdis-*.so放在目录$JAVA_HOME/jre/lib/amd64/server下.
运行命令:
- java -XX:+UnlockDiagnosticVMOptions -XX:+PrintAssembly VolatileBarrierExample
产生的汇编代码
- VM option '+UnlockDiagnosticVMOptions'
- VM option '+PrintAssembly'
- OpenJDK 64-Bit Server VM warning: PrintAssembly is enabled; turning on DebugNonSafepoints to gain additional output
- Loaded disassembler from hsdis-amd64.so
- Decoding compiled method 0x00007fae110f5890:
- Code:
- [Disassembling for mach='i386:x86-64']
- [Entry Point]
- [Constants]
- # {method} 'readAndWrite' '()V' in 'VolatileBarrierExample'
- # [sp+0x20] (sp of caller)
- 0x00007fae110f59c0: mov 0x8(%rsi),%r10d
- 0x00007fae110f59c4: cmp %r10,%rax
- 0x00007fae110f59c7: jne 0x00007fae110cd920 ; {runtime_call}
- 0x00007fae110f59cd: nop
- 0x00007fae110f59ce: nop
- 0x00007fae110f59cf: nop
- [Verified Entry Point]
- 0x00007fae110f59d0: push %rbp
- 0x00007fae110f59d1: sub $0x10,%rsp
- 0x00007fae110f59d5: nop ;*synchronization entry
- ; - VolatileBarrierExample::readAndWrite@-1 (line 13)
- 0x00007fae110f59d6: mov 0x18(%rsi),%r10 ;*getfield v1
- ; - VolatileBarrierExample::readAndWrite@1 (line 13)
- 0x00007fae110f59da: mov 0x20(%rsi),%r11 ;*getfield v2
- ; - VolatileBarrierExample::readAndWrite@6 (line 14)
- 0x00007fae110f59de: mov %r10,%r8
- 0x00007fae110f59e1: add %r11,%r8
- 0x00007fae110f59e4: mov %r8,0x10(%rsi)
- 0x00007fae110f59e8: shl %r10
- 0x00007fae110f59eb: add $0x1,%r11
- 0x00007fae110f59ef: mov %r11,0x18(%rsi)
- 0x00007fae110f59f3: mov %r10,0x20(%rsi) ;*putfield v2
- ; - VolatileBarrierExample::readAndWrite@36 (line 18)
- 0x00007fae110f59f7: add $0x10,%rsp
- 0x00007fae110f59fb: pop %rbp
- 0x00007fae110f59fc: test %eax,0xa6875fe(%rip) # 0x00007fae1b77d000
- ; {poll_return}
- ……….
如果只查看某个方法产生的汇编代码,可以使用命令:
- java -XX:+UnlockDiagnosticVMOptions -XX:CompileCommand=print,*VolatileBarrierExample.readAndWrite VolatileBarrierExample
如果运行命令是出现此错误:
Could not load hsdis-amd64.so; library notloadable; PrintAssembly is disabled
可以设置
- export LD_LIBRARY_PATH=$JAVA_HOME/jre/lib/amd64/server/
参考资料:
1. http://chaoslawful.info/archives/387
2. https://wikis.oracle.com/display/HotSpotInternals/PrintAssembly
使用hsdis查看jit生成的汇编代码的更多相关文章
- GCC生成的汇编代码
假设我们写了一个C代码文件 code.c包含下面代码: int accum = 0; int sum(int x, int y){ int t = x + y; accum += t; return ...
- 利用hsdis和JITWatch查看分析HotSpot JIT compiler生成的汇编代码
http://blog.csdn.net/hengyunabc/article/details/26898657
- 如何在windows平台下使用hsdis与jitwatch查看JIT后的汇编码
1. 安装hsids 这一步比较麻烦,需要提前安装cygwin,以及下载openjdk的源码 具体步骤请参考下面的两篇文章 How to build hsdis-amd64.dll and hsdis ...
- 【JVM】-NO.110.JVM.1 -【hsdis jitwatch 生成查看汇编代码】
Style:Mac Series:Java Since:2018-09-10 End:2018-09-10 Total Hours:1 Degree Of Diffculty:5 Degree Of ...
- 使用gcc不同选项来编译查看中间生成文件
gcc编译C程序的总体流程如下图 用到的命令如下: .c---> .i gcc -E hello.c .c--->.s gcc -S hello.c .c--->.o gcc -c ...
- 分析一个C语言程序生成的汇编代码-《Linux内核分析》Week1作业
署名信息 郭春阳 原创作品转载请注明出处 :<Linux内核分析>MOOC课程 http://mooc.study.163.com/course/USTC-1000029000 C源码 这 ...
- 解析c语言背后的汇编代码
源码 很简单的c语言代码,作用是交换两个数: #include <stdio.h> void swap(int * a, int * b) { *a = *a + *b - (*b = * ...
- Keil 中关于C语言编译生成汇编代码函数名规则
在keil 中 C语言的函数有带参数和不带参数之分. 一般的资料里说fun(void)类型的函数不带参数,所以,keil编译器生成的汇编的调用地址(函数名) 为fun.这没有错.事实上,不管C语言的函 ...
- 通过反汇编一个简单的C程序,分析汇编代码理解计算机是如何工作的
实验一:通过反汇编一个简单的C程序,分析汇编代码理解计算机是如何工作的 学号:20135114 姓名:王朝宪 注: 原创作品转载请注明出处 <Linux内核分析>MOOC课程http: ...
随机推荐
- 如何去掉Json字符串中反斜杠
做项目的时候,遇到了这样的问题,前台传来的Json字符串在实体类中不对应(无法转换为实体类),而且传来的数据项是跟着数据库中的表的变动而变动的(不能重写实体类). 前台Json字符串为: string ...
- 转载--博弈问题及SG函数(真的很经典)
博弈问题若你想仔细学习博弈论,我强烈推荐加利福尼亚大学的Thomas S. Ferguson教授精心撰写并免费提供的这份教材,它使我受益太多.(如果你的英文水平不足以阅读它,我只能说,恐怕你还没到需要 ...
- [洛谷P2730] 魔板 Magic Squares
洛谷题目链接:魔板 题目背景 在成功地发明了魔方之后,鲁比克先生发明了它的二维版本,称作魔板.这是一张有8个大小相同的格子的魔板: 1 2 3 4 8 7 6 5 题目描述 我们知道魔板的每一个方格都 ...
- 不谈OI:高二(13)最后一次班班有歌声
最后一次班班有歌声了…… 自己因为搞oi并没有参加,只是决赛的时候幕后放了放背景视频…… 不管怎么说,我们班唱的很棒啊,全部人都很棒! 说真的我为我们班骄傲 视频: https://v.qq.com/ ...
- 51nod 1076 2条不相交的路径
给出一个无向图G的顶点V和边E.进行Q次查询,查询从G的某个顶点V[s]到另一个顶点V[t],是否存在2条不相交的路径.(两条路径不经过相同的边) (注,无向图中不存在重边,也就是说确定起点和终点 ...
- float/文档流
float : left | right | none | inherit; 文档流是文档中可显示对象在排列时所占用的位置. 浮动的定义: 使元素脱离文档流,按照指定方向发生移动,遇到父级边界或者相邻 ...
- xampp命令
XAMPP命令安装 XAMPPtar xvfz xampp-linux-1.6.4.tar.gz -C /opt启动 XAMPP/opt/lampp/lampp start停止 XAMPP/opt/l ...
- bzoj 1044 贪心二分+DP
原题传送门http://www.lydsy.com/JudgeOnline/problem.php?id=1044 首先对于第一问,我们可以轻易的用二分答案来搞定,对于每一个二分到的mid值 我们从l ...
- cobalt strike使用笔记
启动: ./teamserver 192.168.74.1 admin #启动cs服务器.admin为密码. 监听器: windows/beacon_dns/reverse_dns_txtwindow ...
- rtp/rtsp over http的学习
要做rtp/rtsp over http, 我对http也有点了解, 以前也做过rtp/rtsp over tcp/udp传输264视频流, 但刚开始还是没有一点思路,想着把http和rtp等联系到一 ...