使用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: ...
随机推荐
- js密码的匹配正则
匹配的密码是 数字大写或者小写的字母.符号. if(pwd.match(/[\d]/) && pwd.match(/[A-Za-z]/) && pwd.match(/[ ...
- 【LuoguP1273有线电视网】树形依赖背包
参考论文http://wenku.baidu.com/view/8ab3daef5ef7ba0d4a733b25.html 参考一篇写的很好的博文http://www.cnblogs.com/GXZC ...
- 【HDU】6146 Pokémon GO
[题意]一个2*n的网格,再保证步数最少的情况下,求从任意格出发遍历完所有格的方案数,格子八连通.n<=10000,T<=100. [算法]递推,DP [题解]原题链接:蓝桥杯 格子刷油漆 ...
- Type of flip id
http://www.haskell.org/pipermail/beginners/2011-March/006477.html The point is that the type of id h ...
- html怎样让表格里面的内容居中
html怎样让表格里面的内容居中 text-align:center; 在表格td中,有两个属性控制居中显示 align——表示左右居中——left,center,right valign——控制上下 ...
- CentOS下使用Iptraf进行网络流量的分析笔记
CentOS下使用Iptraf进行网络流量的分析笔记 一.概述 Iptraf是一款linux环境下,监控网络流量的一款绝佳的免费小软件. 本博客其他随笔参考: Centos安装流量监控工具iftop笔 ...
- python 判断质数还是合数
while 1: s = input('请输入一个数:') s = int(s) if s == 2: print('质数') else: if s == 0 or s == 1: print('都不 ...
- Appium+python自动化27-android特有的wait_activity【转载】
本篇转自博客:上海-悠悠 前言在启动app的时候,如果直接做下一步点击操作,经常会报错,于是我们会在启动完成的时候加sleep.那么问题来了,这个sleep时间到底设置多少合适呢?设置长了,就浪费时间 ...
- 准备开发开放API接口
准备开发APP开放接口,允许JQUERY直接调用http://blog.csdn.net/wuxiangege/article/details/52238968 SIGN的设计与实现http://bl ...
- css样式表中的样式覆盖顺序(转)
有时候在写CSS的过程中,某些限制总是不起作用,这就涉及了CSS样式覆盖的问题,如下 Css代码 #navigator { height: 100%; width: 200; position: ...