草庐IT

读Java性能权威指南(第2版)笔记09_即时编译器下

躺柒 2023-03-28 原文

1. CPU相关代码

1.1. Advanced Vector Extensions

1.1.1. AVX

1.1.2. 2013年,Intel为Haswell以及之后的芯片引入了AVX2

1.1.3. 2016年,Intel又引入了AVX-512指令

1.1.4. JDK 8不支持这些指令

1.1.5. JDK 11支持

1.2. -XX:UseAVX=N

1.2.1. 0

1.2.1.1. 不使用AVX指令

1.2.2. 1

1.2.2.1. 使用Intel AVX 1指令(对于Sandy Bridge和之后的处理器)

1.2.3. 2

1.2.3.1. 使用Intel AVX 2指令(对于Haswell和之后的处理器)

1.2.4. 3

1.2.4.1. 使用Intel AVX-512指令(对于Knights Landing和之后的处理器)

1.3. -XX:UseSSE=N

1.3.1. 支持Intel流SIMD扩展1到4

1.3.1.1. Streaming SIMD Extensions,SSE

1.3.2. 针对奔腾系列处理器的

2. 分层编译的权衡

2.1. 当在内存受限的环境中运行时有理由关闭它

2.2. 给定足够长的预热期,禁用分层编译时的执行情况和开启时应该是差不多的

2.3. javac编译器

2.3.1. 包含额外调试信息的-g标志不会影响性能

2.3.2. 在Java应用程序中使用final关键字并不能更快地编译代码

2.3.3. 用较新的javac版本重新编译通常不会使应用程序更快

2.3.3.1. JDK 11引入了一种新的字符串连接方式,可以比以前的版本更快,但需要重新编译代码才能用

3. GraalVM

3.1. 一个新的虚拟机

3.1.1. 可以运行许多其他语言的代码

3.2. 两个版本

3.2.1. 完全开源的社区版(Community Edition,CE)

3.2.1.1. 社区版比企业版慢

3.2.2. 商用的企业版(Enterprise Edition,EE)

3.3. 对JVM性能有两个重要贡献

3.3.1. 插件技术允许GraalVM生成完全原生的二进制文件

3.3.2. 以常规JVM的模式运行,只是它包含了一个新的C2编译器实现

3.3.2.1. 这个编译器是用Java写的

3.3.2.2. 传统的C2编译器是用C++写的

3.4. -XX:+UnlockExperimentalVMOptions

3.4.1. 默认值是false

3.5. -XX:+EnableJVMCI

3.5.1. 默认值是false

3.6. -XX:+UseJVMCICompiler

3.6.1. 默认值是false

4. 提前编译

4.1. ahead-of-time compilation,简称AOT compilation

4.2. 最初仅在JDK 9的Linux版本中可用

4.2.1. JDK 11时所有平台都可以用了

4.3. 启动速度更快

4.3.1. 目前,应用程序类数据共享给启动性能带来的提升更大,而且它已经是平台完全支持的特性

4.3.2. 提前编译针对的是像REST服务器这样启动时间相对比较长的程序

4.3.2.1. 加载共享库的时间就被较长的启动时间抵消了,提前编译就更有优势

4.4. jaotc工具

4.4.1. 生成一个共享库,其中包含你选出的编译过的类

4.4.2. 然后通过运行参数将共享库加载到JVM中

$ java -XX:+UnlockDiagnosticVMOptions -XX:+LogTouchedMethods \
      -XX:+PrintTouchedMethodsAtExit <other arguments>
java/net/URI.getHost:()Ljava/lang/String;

4.4.5. 为了生成methods.txt文件,需要保存这些输出内容,然后在每一行前添加compileOnly命令并删除方法参数之前的冒号

$ jaotc --compile-commands=/tmp/methods.txt \
    --output JavaBaseFilteredMethods.so \
    --compile-for-tiered \
    --module java.base

4.4.7. /tmp/methods.txt文件中

compileOnly java.net.URI.getHost()Ljava/lang/String;

4.5. 如果不让预编译的方法被C2编译器编译,那么服务器预热后的性能就会比它最终可能达到的性能差

4.6. -XX:+PrintAOT

4.6.1. 在预编译方法被JVM使用时会产生输出

4.6.2. 默认值是false

4.7. 对于比较大的程序有好处

4.8. 对于很小的、快速运行的程序没有帮助,甚至会阻碍它们的运行

5. GraalVM原生编译

5.1. 生成不需要JVM的可执行文件

5.1.1. 是短期程序的理想选择

5.2. 生成的二进制文件启动速度很快,特别是相较于在JVM中运行的程序

5.3. GraalVM优化代码时并没有C2编译器那么激进,所以对于运行得足够久的应用程序,传统的JVM最终会胜出

5.4. GraalVM原生二进制文件在执行期间不会使用C2编译器编译类

5.5. 原生程序的内存占用在开始时比传统JVM少得多

5.5.1. 随着程序的运行和堆的增长,这种内存优势会逐渐消失

有关读Java性能权威指南(第2版)笔记09_即时编译器下的更多相关文章

  1. java - 等价于 Java 中的 Ruby Hash - 2

    我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/

  2. ruby - 即时确定方法的可见性 - 2

    我正在编写一个方法,它将在一个类中定义一个实例方法;类似于attr_accessor:classFoocustom_method(:foo)end我通过将custom_method函数添加到Module模块并使用define_method定义方法来实现它,效果很好。但我无法弄清楚如何考虑类(class)的可见性属性。例如,在下面的类中classFoocustom_method(:foo)privatecustom_method(:bar)end第一个生成的方法(foo)必须是公共(public)的,第二个(bar)必须是私有(private)的。我怎么做?或者,如何找到调用我的cust

  3. java - 从 JRuby 调用 Java 类的问题 - 2

    我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www

  4. java - 我的模型类或其他类中应该有逻辑吗 - 2

    我只想对我一直在思考的这个问题有其他意见,例如我有classuser_controller和classuserclassUserattr_accessor:name,:usernameendclassUserController//dosomethingaboutanythingaboutusersend问题是我的User类中是否应该有逻辑user=User.newuser.do_something(user1)oritshouldbeuser_controller=UserController.newuser_controller.do_something(user1,user2)我

  5. java - 什么相当于 ruby​​ 的 rack 或 python 的 Java wsgi? - 2

    什么是ruby​​的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht

  6. Observability:从零开始创建 Java 微服务并监控它 (二) - 2

    这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/

  7. 【Java 面试合集】HashMap中为什么引入红黑树,而不是AVL树呢 - 2

    HashMap中为什么引入红黑树,而不是AVL树呢1.概述开始学习这个知识点之前我们需要知道,在JDK1.8以及之前,针对HashMap有什么不同。JDK1.7的时候,HashMap的底层实现是数组+链表JDK1.8的时候,HashMap的底层实现是数组+链表+红黑树我们要思考一个问题,为什么要从链表转为红黑树呢。首先先让我们了解下链表有什么不好???2.链表上述的截图其实就是链表的结构,我们来看下链表的增删改查的时间复杂度增:因为链表不是线性结构,所以每次添加的时候,只需要移动一个节点,所以可以理解为复杂度是N(1)删:算法时间复杂度跟增保持一致查:既然是非线性结构,所以查询某一个节点的时候

  8. LC滤波器设计学习笔记(一)滤波电路入门 - 2

    目录前言滤波电路科普主要分类实际情况单位的概念常用评价参数函数型滤波器简单分析滤波电路构成低通滤波器RC低通滤波器RL低通滤波器高通滤波器RC高通滤波器RL高通滤波器部分摘自《LC滤波器设计与制作》,侵权删。前言最近需要学习放大电路和滤波电路,但是由于只在之前做音乐频谱分析仪的时候简单了解过一点点运放,所以也是相当从零开始学习了。滤波电路科普主要分类滤波器:主要是从不同频率的成分中提取出特定频率的信号。有源滤波器:由RC元件与运算放大器组成的滤波器。可滤除某一次或多次谐波,最普通易于采用的无源滤波器结构是将电感与电容串联,可对主要次谐波(3、5、7)构成低阻抗旁路。无源滤波器:无源滤波器,又称

  9. 【Java入门】使用Java实现文件夹的遍历 - 2

    遍历文件夹我们通常是使用递归进行操作,这种方式比较简单,也比较容易理解。本文为大家介绍另一种不使用递归的方式,由于没有使用递归,只用到了循环和集合,所以效率更高一些!一、使用递归遍历文件夹整体思路1、使用File封装初始目录,2、打印这个目录3、获取这个目录下所有的子文件和子目录的数组。4、遍历这个数组,取出每个File对象4-1、如果File是否是一个文件,打印4-2、否则就是一个目录,递归调用代码实现publicclassSearchFile{publicstaticvoidmain(String[]args){//初始目录Filedir=newFile("d:/Dev");Datebeg

  10. java - 为什么 ruby​​ modulo 与 java/other lang 不同? - 2

    我基本上来自Java背景并且努力理解Ruby中的模运算。(5%3)(-5%3)(5%-3)(-5%-3)Java中的上述操作产生,2个-22个-2但在Ruby中,相同的表达式会产生21个-1-2.Ruby在逻辑上有多擅长这个?模块操作在Ruby中是如何实现的?如果将同一个操作定义为一个web服务,两个服务如何匹配逻辑。 最佳答案 在Java中,模运算的结果与被除数的符号相同。在Ruby中,它与除数的符号相同。remainder()在Ruby中与被除数的符号相同。您可能还想引用modulooperation.

随机推荐