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

2024-05-02 15:36

本文主要是介绍逃逸分析、栈上分配、标量替换大展神威,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、逃逸分析
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等编程技术的技巧经验分享),若作品对您有帮助,请关注、分享、点赞、收藏、在看、喜欢,您的支持是我们为您提供帮助的最大动力。

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

这篇关于逃逸分析、栈上分配、标量替换大展神威的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/954582

相关文章

[职场] 公务员的利弊分析 #知识分享#经验分享#其他

公务员的利弊分析     公务员作为一种稳定的职业选择,一直备受人们的关注。然而,就像任何其他职业一样,公务员职位也有其利与弊。本文将对公务员的利弊进行分析,帮助读者更好地了解这一职业的特点。 利: 1. 稳定的职业:公务员职位通常具有较高的稳定性,一旦进入公务员队伍,往往可以享受到稳定的工作环境和薪资待遇。这对于那些追求稳定的人来说,是一个很大的优势。 2. 薪资福利优厚:公务员的薪资和

高度内卷下,企业如何通过VOC(客户之声)做好竞争分析?

VOC,即客户之声,是一种通过收集和分析客户反馈、需求和期望,来洞察市场趋势和竞争对手动态的方法。在高度内卷的市场环境下,VOC不仅能够帮助企业了解客户的真实需求,还能为企业提供宝贵的竞争情报,助力企业在竞争中占据有利地位。 那么,企业该如何通过VOC(客户之声)做好竞争分析呢?深圳天行健企业管理咨询公司解析如下: 首先,要建立完善的VOC收集机制。这包括通过线上渠道(如社交媒体、官网留言

打包体积分析和优化

webpack分析工具:webpack-bundle-analyzer 1. 通过<script src="./vue.js"></script>方式引入vue、vuex、vue-router等包(CDN) // webpack.config.jsif(process.env.NODE_ENV==='production') {module.exports = {devtool: 'none

Java中的大数据处理与分析架构

Java中的大数据处理与分析架构 大家好,我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编,也是冬天不穿秋裤,天冷也要风度的程序猿!今天我们来讨论Java中的大数据处理与分析架构。随着大数据时代的到来,海量数据的存储、处理和分析变得至关重要。Java作为一门广泛使用的编程语言,在大数据领域有着广泛的应用。本文将介绍Java在大数据处理和分析中的关键技术和架构设计。 大数据处理与

段,页,段页,三种内存(RAM)管理机制分析

段,页,段页         是为实现虚拟内存而产生的技术。直接使用物理内存弊端:地址空间不隔离,内存使用效率低。 段 段:就是按照二进制文件的格式,在内存给进程分段(包括堆栈、数据段、代码段)。通过段寄存器中的段表来进行虚拟地址和物理地址的转换。 段实现的虚拟地址 = 段号+offset 物理地址:被分为很多个有编号的段,每个进程的虚拟地址都有段号,这样可以实现虚实地址之间的转换。其实所谓的地

mediasoup 源码分析 (八)分析PlainTransport

mediasoup 源码分析 (六)分析PlainTransport 一、接收裸RTP流二、mediasoup 中udp建立过程 tips 一、接收裸RTP流 PlainTransport 可以接收裸RTP流,也可以接收AES加密的RTP流。源码中提供了一个通过ffmpeg发送裸RTP流到mediasoup的脚本,具体地址为:mediasoup-demo/broadcaste

Java并发编程—阻塞队列源码分析

在前面几篇文章中,我们讨论了同步容器(Hashtable、Vector),也讨论了并发容器(ConcurrentHashMap、CopyOnWriteArrayList),这些工具都为我们编写多线程程序提供了很大的方便。今天我们来讨论另外一类容器:阻塞队列。   在前面我们接触的队列都是非阻塞队列,比如PriorityQueue、LinkedList(LinkedList是双向链表,它实现了D

线程池ThreadPoolExecutor类源码分析

Java并发编程:线程池的使用   在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题:   如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统的效率,因为频繁创建线程和销毁线程需要时间。   那么有没有一种办法使得线程可以复用,就是执行完一个任务,并不被销毁,而是可以继续执行其他的任务?

ConcurrentHashMap之源码分析

集合是编程中最常用的数据结构。而谈到并发,几乎总是离不开集合这类高级数据结构的支持。比如两个线程需要同时访问一个中间临界区(Queue),比如常会用缓存作为外部文件的副本(HashMap)。这篇文章主要分析jdk1.5的3种并发集合类型(concurrent,copyonright,queue)中的ConcurrentHashMap,让我们从原理上细致的了解它们,能够让我们在深度项目开发中获益非浅

Hashtable的源码分析

Hashtable简介     Hashtable同样是基于哈希表实现的,同样每个元素是一个key-value对,其内部也是通过单链表解决冲突问题,容量不足(超过了阀值)时,同样会自动增长。     Hashtable也是JDK1.0引入的类,是线程安全的,能用于多线程环境中。     Hashtable同样实现了Serializable接口,它支持序列化,实现了Cloneable接