文章目录

  • 简介
  • 使用PrintAssembly
  • 输出过滤
  • 总结

简介

想不想了解JVM最最底层的运行机制?想不想从本质上理解java代码的执行过程?想不想对你的代码进行进一步的优化和性能提升?

如果你的回答是yes。那么这篇文章非常适合你,因为本文将会站在离机器码最近的地方来观看JVM的运行原理:Assembly。

使用PrintAssembly

小师妹:F师兄,上次你给我介绍了java中的字节码,还有JIT中的LogCompilation和PrintCompilation的用法。虽然都非常有用,但是能不能更进一步,让我能以机器的眼光来看待JVM的执行?

小师妹,如果要探究JVM的运行本质,那就应该是机器码了。难道你要去读懂机器码?虽然我不是机器码的专家,但我猜那应该是个非常复杂的过程。

小师妹:F师兄,当然不是机器码,有没有比机器码更高级一点点的,我记得上大学的时候学过汇编语言,好像就是离机器码最近的语言了,JVM有没有相应的汇编语言呢?

必须有的,我们可以使用-XX:+PrintAssembly来将assembly打印出来。

但是打印assembly是有条件的,它就像一个高傲的姑娘,不是你想追求就能追求得上的。

我们使用下面的命令来查看系统对PrintAssembly的支持程度:

java -XX:+UnlockDiagnosticVMOptions -XX:+PrintAssembly -versionJava HotSpot(TM) 64-Bit Server VM warning: PrintAssembly is enabled; turning on DebugNonSafepoints to gain additional output
Could not load hsdis-amd64.dylib; library not loadable; PrintAssembly is disabled
java version "1.8.0_171"
Java(TM) SE Runtime Environment (build 1.8.0_171-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.171-b11, mixed mode)

根据大家的运行环境的不同,得到的结果可能也是不同的,我是mac的系统,从上面的结果可以看到,在我的JDK8的环境中,显示缺少hsdis-amd64.dylib,所以PrintAssembly其实是禁用的。

小师妹:F师兄,那现在咋办呀?没有hsdis-amd64.dylib就用不了PrintAssembly了。

巴甫洛夫说过:问号是开启任何一门科学的钥匙。没有问题我们就创造问题,没有困难我们就制造困难,没有hsdis-amd64.dylib当然是安装咯。

具体怎么安装,大家自行探索吧,网上有很多安装的教程,这里就不一一介绍了。

这里想讨论一个很奇怪的事情,虽然在JDK8环境中,我们不能使用PrintAssembly,因为没有hsdis-amd64.dylib。但是当我切到最新的JDK14环境中,一切都很美好,PrintAssembly可以正常运行了。

如果我们在JDK14中同样运行上面的命令,我们会得到下面的结果:

上图说明JDK14中虽然可以正常运行但是结果却不是assembly code,说明在JDK14中还是需要安装hsdis-amd64.dylib才能够得到正确的assembly结果。

注意,JDK14也需要安装hsdis-amd64.dylib才能正确使用。

输出过滤

默认情况下,PrintAssembly输出的是所有的信息,但是JDK内部的代码我们不可能进行修改,一般来说并不关心他们的assembly输出,如果要指定我们自己编写的方法,可以使用CompileCommand:

CompileCommand=print,*MyClass.myMethod prints assembly for just one method
CompileCommand=option,*MyClass.myMethod,PrintOptoAssembly (debug build only) produces the old print command output
CompileCommand=option,*MyClass.myMethod,PrintNMethods produces method dumps

例如:

-XX:CompileCommand=print,com.flydean.PrintAssemblyUsage::testPrintAssembly

这样我们可以得到,只属于testPrintAssembly方法的输出:

总结

本文讲解了怎么使用PrintAssembly来输出JVM的汇编日志。我们会在后面继续讲解这些Assembly code到底有什么用。

本文的例子https://github.com/ddean2009/learn-java-base-9-to-20

本文作者:flydean程序那些事

本文链接:http://www.flydean.com/jvm-jit-printassembly/

本文来源:flydean的博客

欢迎关注我的公众号:程序那些事,更多精彩等着您!

小师妹学JVM之:JIT中的PrintAssembly相关推荐

  1. 小师妹学JVM之:JIT中的PrintAssembly续集

    文章目录 简介 JDK8和JDK14中的PrintAssembly JDK8中使用Assembly JDK14中的Assembly 在JMH中使用Assembly 总结 简介 上篇文章和小师妹一起介绍 ...

  2. 小师妹学JVM之:JIT中的PrintCompilation

    文章目录 简介 PrintCompilation 分析PrintCompilation的结果 总结 简介 上篇文章我们讲到了JIT中的LogCompilation,将编译的日志都收集起来,存到日志文件 ...

  3. 小师妹学JVM之:JIT中的LogCompilation

    文章目录 简介 LogCompilation简介 LogCompilation的使用 解析LogCompilation文件 总结 简介 我们知道在JVM中为了加快编译速度,引入了JIT即时编译的功能. ...

  4. 小师妹学JVM之:JDK14中JVM的性能优化

    文章目录 简介 String压缩 分层编译(Tiered Compilation) Code Cache分层 新的JIT编译器Graal 前置编译 压缩对象指针 Zero-Based 压缩指针 Esc ...

  5. 小师妹学JVM之:JVM中的Safepoints

    文章目录 简介 GC的垃圾回收器 分代回收器中的问题 safepoints safepoint一般用在什么地方 总结 简介 java程序员都听说过GC,大家也都知道GC的目的是扫描堆空间,然后将那些标 ...

  6. 小师妹学JVM之:深入理解JIT和编译优化-你看不懂系列

    文章目录 简介 JIT编译器 Tiered Compilation分层编译 OSR(On-Stack Replacement) Deoptimization 常见的编译优化举例 Inlining内联 ...

  7. 小师妹学JVM之:cache line对代码性能的影响

    文章目录 简介 一个奇怪的现象 两个问题的答案 CPU cache line inc 和 add 总结 简介 读万卷书不如行万里路,讲了这么多assembly和JVM的原理与优化,今天我们来点不一样的 ...

  8. 小师妹学JVM之:JVM的架构和执行过程

    文章目录 简介 JVM是一种标准 java程序的执行顺序 JVM的架构 类加载系统 运行时数据区域 执行引擎 总结 简介 JVM也叫Java Virtual Machine,它是java程序运行的基础 ...

  9. 小师妹学JVM之:Dirty cards和PLAB

    文章目录 简介 分代收集器中的空间划分 Write barrier和Dirty cards PLAB old space分配对象 总结 简介 分代垃圾回收器在进行minor GC的时候会发生什么操作呢 ...

最新文章

  1. BUUCTF(pwn)bjdctf_2020_babystack2
  2. Scikit-Learn 机器学习笔记 -- 决策树
  3. c++设计模式编程基础
  4. python几乎无所不能 只有你不知道的,如何通过Python玩转小视频
  5. 使用go开启一个能够提供给html的a标签的下载的后端
  6. 【黑金原创教程】【FPGA那些事儿-驱动篇I 】实验十八:SDRAM模块① — 单字读写...
  7. logging.getLogger(logger)
  8. WordPress插件-Wordfence Security v7.4汉化版-可更新
  9. OSChina 周五乱弹 —— 你专业是啥,被叫去搬砖了吗?
  10. 红外倒车雷达原理图_自动驾驶汽车传感器技术解析—毫米波雷达
  11. 星巴克——最单纯的SNS应用
  12. Hyperledger Fabric教程(11)-- 链码和背书策略
  13. Atitit.注重细节还是关注长远??长远优先
  14. NetVLAD: CNN architecture for weakly supervised place recognition 翻译
  15. server 2016备份还原
  16. 方框加对勾怎么输入_word里如何往方框中加对号?带方框的对号怎么弄,原来是这样的...
  17. 2009 year English Inprovement for IT developments
  18. 上 k8s 生产环境的一些准备!
  19. JavaScript高级程序设计(红宝石书)学习笔记
  20. 5G 核心网 Inter NG-RAN node N2 based handover 信令流程

热门文章

  1. UVA208Firetruck 消防车(图的路径搜索)
  2. 广度优先遍历算法-01寻找制高点问题
  3. Web开发-Django初识及实战
  4. python高级语法-高阶函数之map的使用方法
  5. android qq 登陆 简书,使用QQ第三方登录
  6. php 下载的压缩文件,php在线压缩打包rar并自动下载文件的例子
  7. PE文件结构详解(二)可执行文件头
  8. OD消息断点的设置方法
  9. Kafka参数broker.id详解
  10. [译]提案:在Go语言中增加对持久化内存的支持