美文网首页编程语言后端开发
逃逸分析、栈上分配、标量替换大展神威

逃逸分析、栈上分配、标量替换大展神威

作者: 程序员小迷 | 来源:发表于2024-05-01 14:22 被阅读0次

一、逃逸分析

1.逃逸分析的目的是判断对象的作用域是否会逃逸出方法体(方法逃逸)或者外部线程(线程逃逸)。

2.注意,任何可以在多个线程之间共享的对象,一定都属于逃逸对象。

3.若重写了一个类的finalize方法,则这个类的变量会被标记为全局逃逸状态,且会被放在堆内存中。

4.若一个对象不会逃逸到方法或其他线程之外,则可以对此对象进行高效优化。

5.默认情况下32位的hotspot虚拟机都是client模式;64位的的都是server模式。那么32位的虚拟机就一定是client模式,64位的虚拟机就一定是server模式吗?当然不是,这个可以通过配置文件来永久性的调整。

配置文件的位置:32位的虚拟机在%JAVA_HOME%/jre/lib/i386/jvm.cfg

64位的虚拟机在%JAVA_HOME%/jre/lib/amd64/jvm.cfg

比如我们用Eclipse或者MyEclipse运行程序,一般使用的都是工具自带的JRE,虚拟机并不是本地安装的虚拟机。这时候可以通过在程序中运行下面的语句来查看虚拟机信息:

System.out.println(System.getProperty("java.vm.name"));

6.逃逸分析可以识别出以下几种情况:

1)全局逃逸:对象可以被外部访问。

2)局部逃逸:对象只能被方法内的代码或访问到此对象的外部方法访问。

3)无逃逸:对象仅在方法内部使用,外部不可使用。

7.若逃逸分析确定一个变量不会逃逸出线程,则这个变量不会有多线程竞争问题,所以变量的同步措施(例如:锁)就可以被消除了。

8.逃逸分析是为其他优化提供依据的分析技术。

-server JVM运行的模式之一, server模式才能进行逃逸分析, JVM运行的模式还有mixed和client。

-XX:+DoEscapeAnalysis:启用逃逸分析(默认开启)

-XX:+PrintEscapeAnalysis:查看逃逸分析结果(默认开启)

-XX:+EliminateAllocations:开启标量替换(默认开启)

-XX:+PrintEliminateAllocations:查看标量替换情况(默认开启)

-XX:+EliminateLocks:开启锁消除(默认开启)

-XX:+PrintGC:打印GC日志

-XX:-UseTLAB:关闭本地线程分配缓冲

TLAB: Thread Local Allocation Buffer(本地线程分配缓冲)

二、栈上分配

1.虚拟机提供的一种优化技术,基本思想是,对于线程私有的对象,将它分配在栈上,而不分配在堆上。好处是对象跟着方法调用自行销毁,不需要进行垃圾回收,可以提高性能。

2.栈上分配需要的技术基础为逃逸分析。

3.若通过逃逸分析确认对象不会被外部访问到的话,则直接在栈上分配对象。这样这个对象在栈帧出栈时即被销毁,可以减少堆内存的使用,降低垃圾回收的压力。

4.栈的分配与回收比堆快。栈空间较小且高效,适合短生命周期的对象。

5.如何启用栈上分配:

对栈上分配发生影响的参数有三个,-server、-XX:+DoEscapeAnalysis和-XX:+EliminateAllocations,任何一个发生变化都不会发生栈上分配。因为启用逃逸分析和标量替换默认是打开的,所以,JVM的参数只用-server时一样可以有栈上分配的效果。

三、标量替换

1.若逃逸分析证明一个对象不会被外部访问,且此对象可以拆分,则可以使用标量替换。这些标量可以直接分配在栈上或寄存器中,可提高程序执行效率。

2.将对象使用到的成员变量以原始类型来访问就叫做标量替换。

3.标量替换需要的技术基础为逃逸分析。

4.标量替换通常在JIT(即时编译)时进行。

5.标量替换可以大大减少堆内存的占用及垃圾回收压力。

6.标量替换可以看作是栈上分配的一个特例。

四、总结

基于逃逸分析这个编译器优化技术,可以使用栈上分配和标量替换等优化手段来提高程序运行性能。


微风不燥,阳光正好,你就像风一样经过这里,愿你停留的片刻温暖舒心。

我是程序员小迷(致力于C、C++、Java、Kotlin、Android、Shell、JavaScript、TypeScript、Python等编程技术的技巧经验分享),若作品对您有帮助,请关注、分享、点赞、收藏、在看、喜欢,您的支持是我们为您提供帮助的最大动力。

欢迎关注。助您在编程路上越走越好!

相关文章

  • JVM 对象分配过程

    对象分配过程 1)依据逃逸分析,判断是否能栈上分配? 如果可以,使用标量替换方式,把对象分配到VM Stack中。...

  • JIT 编译器(Just In Time Compiler) 如

    1.方法内联 2.逃逸分析 栈上分配标量替换(并不是所有的对象或者数组,都会在堆上分配)同步消除

  • 逃逸分析&栈上分配&标量替换&同步消除

    逃逸分析 逃逸分析分基本行为就是分析对象动态作用域:当一个对象被定义后,它可能被外部方法引用,例如作为调用参数被传...

  • JVM学习笔记与调优实战(三):Java对象内存分配与逃逸分析

    标签: JVM 1、Java对象的分配: 栈上分配线程私有小对象无逃逸支持标量替换无需调整(虚拟机自动优化,无需调...

  • golang的变量内存分配

    逃逸分析 逃逸分析不是直接的优化手段,而是一个代码分析,通过动态分析对象的作用域,为其它优化手段如栈上分配、标量替...

  • JVM 之逃逸分析

    逃逸分析 逃逸分析并不是直接的优化手段,而是一个代码分析,通过动态分析对象的作用域,为其它优化手段如栈上分配、标量...

  • JAVA逃逸分析、栈上分配、标量替换、同步消除

    一、逃逸分析 逃逸分析是编译语言中的一种优化分析,而不是一种优化的手段。通过对象的作用范围的分析,为其他优化手段提...

  • 逃逸分析、标量替换、线程本地分配

    栈上分配1.线程私有小对象2.无逃逸,就在某段代码中使用3.支持标量替换无需调整 线程本地分配TLAB(Threa...

  • go 逃逸分析

    go 逃逸分析 什么是逃逸分析 逃逸分析决定一个变量是分配在堆上还是分配在栈上 原理 逃逸分析这种“骚操作”把变量...

  • 栈上分配(逃逸分析)

    栈上分配(逃逸分析) 分析 ​ 逃逸分析的基本行为就是分析对象动态作用域:当一个对象在方法中被定义后,它可以能...

网友评论

    本文标题:逃逸分析、栈上分配、标量替换大展神威

    本文链接:https://www.haomeiwen.com/subject/kmbffjtx.html