volatile的扩展分析(1)———分析JIT编译器优化

简介: volatile的扩展分析(1)———分析JIT编译器优化

前言

提示:最近在写volatile的时候,涉及到了编译器优化的部分内容,写在voaltile里内容有点臃肿,单独写一篇博客来聊聊好了,直接先上一段代码:

public class VolatileClass {
    private static boolean isRunning = true;
    private static int i = 0;
    public static void main(String[] args) {
        Thread thread = new Thread(() -> {
            while (isRunning) {
                i++;
            }
        });
        thread.start();
        try {
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        isRunning = false;
        System.out.println("isRunning has been changed to false");
    }
}

一、JIT 即时编译器的分类

我们知道,HotSpot集成了两个JIT compiler — C1及C2(或称为Client及Server)

两者的区别在于,前者没有应用激进的优化技术,因为这些优化往往伴随着耗时较长的代码分析。因此,C1的编译速度较快,而C2所编译的方法运行速度较快。

这两个JIT compiler(C1与C2)以及interpreter(解释器)将HotSpot的执行方式划分为五个级别:


level 0:interpreter解释执行

level 1:C1编译,无profiling(性能监控功能)

level 2:C1编译,仅方法及循环back-edge执行次数的profiling((性能监控功能))

level 3:C1编译,除level2中的profiling外还包括branch(针对分支跳转字节码)及receivertype(针对成员方法调用或类检测,如checkcast,instnaceof,aastore字节码)的profiling

level 4:C2编译

二、优化结果查看

1. 无volatile C2-level4级

7c5570fa6e6a4c68a57d152749e82020.png

可以看到jmp L0000 回跳到了inc 指令,也就是我们代码里的i++。换句话说,第一次进入循环会读我们的isRuning变量,读入寄存器后,做一个判断,但是也仅有一次判断。后续直接把循环判断的判断给去掉了,直接变成无限执行循环体了


2. 有volatile C2-level4级

我们对isRuning加了volatile,然后再运行看看情况

3b352695a22c48b3b1e9dc957c9c0da4.png

可以看到对isRuning加了volatile之后,编译器编译后的结果发生了改变,每次进行循环之前,会对isRuning再做一遍取值,如果不为0,则跳转到L0000,即满足条件再执行循环体的内容


目录
相关文章
|
8月前
|
存储 算法 编译器
C/C++编译器局部优化技术:局部优化是针对单个函数或基本块进行的优化
C/C++编译器局部优化技术:局部优化是针对单个函数或基本块进行的优化
243 0
|
数据中心 Anolis
性能优化特性之:LSE指令集编译优化
本文介绍了倚天实例上的编译优化特性:LSE,并从优化原理、使用方法进行了详细阐述。
|
3月前
|
存储 缓存 监控
聊聊JIT是如何影响JVM性能的!
聊聊JIT是如何影响JVM性能的!
|
6月前
|
编译器 C++ 运维
开发与运维编译问题之volatile和atomic帮助抑制编译器优化如何解决
开发与运维编译问题之volatile和atomic帮助抑制编译器优化如何解决
43 2
|
5月前
|
Java 测试技术
hyengine microbench测试问题之提升jit优化如何解决
hyengine microbench测试问题之提升jit优化如何解决
|
8月前
|
安全 数据可视化 测试技术
使用unsfae和运行时库分析性能
【5月更文挑战第19天】该文探讨了Go语言中使用`runtime`和`unsafe`包对资源使用率的影响。`unsafe`包允许绕过类型安全,但不保证兼容性,使用时需谨慎。`runtime`包提供运行时分析,包括内存分配统计。总结中提到,`unsafe`转换在某些情况下能提升约4倍效率。接下来的内容会涉及更多性能优化策略。
48 0
使用unsfae和运行时库分析性能
|
7月前
|
存储 缓存 Java
JVM的即时编译(JIT)优化原理:加速程序的执行
JVM的即时编译(JIT)优化原理:加速程序的执行
|
8月前
|
监控 安全 Java
JVM工作原理与实战(三十八):JIT即时编译器原理
JVM作为Java程序的运行环境,其负责解释和执行字节码,管理内存,确保安全,支持多线程和提供性能监控工具,以及确保程序的跨平台运行。本文主要介绍了JIT即时编译器、HotSpot中的JIT编译器、JIT优化技术、JIT优化建议等内容。
150 0
|
8月前
|
存储 Rust 安全
Rust中避免不必要的内存分配与复制的优化策略
在Rust编程语言中,内存分配与复制是常见的性能瓶颈。本文深入探讨了如何在Rust中避免不必要的内存分配和复制,包括使用栈分配、借用与所有权、智能指针、以及零拷贝策略等。通过理解这些概念并应用相应的优化策略,Rust开发者可以显著提高代码的性能和效率。
|
8月前
|
缓存 编译器 程序员
C/C++编译器全局优化技术:全局优化是针对整个程序进行的优化,包括函数之间的优化
C/C++编译器全局优化技术:全局优化是针对整个程序进行的优化,包括函数之间的优化
220 0