溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

JVM對(duì)象為什么一定在堆中分配

發(fā)布時(shí)間:2021-08-30 16:56:08 來(lái)源:億速云 閱讀:120 作者:chen 欄目:開發(fā)技術(shù)

這篇文章主要介紹“JVM對(duì)象為什么一定在堆中分配”,在日常操作中,相信很多人在JVM對(duì)象為什么一定在堆中分配問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”JVM對(duì)象為什么一定在堆中分配”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

目錄
  • JVM運(yùn)行時(shí)數(shù)據(jù)區(qū)域:

  • 逃逸分析技術(shù)存在的問(wèn)題:

  • 逃逸分析JVM參數(shù)設(shè)置:

JVM運(yùn)行時(shí)數(shù)據(jù)區(qū)域:

JVM運(yùn)行時(shí)的數(shù)據(jù)區(qū)域可以分為:虛擬機(jī)棧、本地方法棧、方法區(qū)、程序計(jì)數(shù)器、堆。一般我們都說(shuō)一切的對(duì)象的分配都是在堆中進(jìn)行分配的,即使是棧中的對(duì)象,棧也只是保存了該對(duì)象的引用,真正的對(duì)象仍然存儲(chǔ)在堆中。

JVM對(duì)象為什么一定在堆中分配

然而實(shí)際上,對(duì)象并不總是在堆中進(jìn)行分配的,這里就需要介紹一下JVM的逃逸分析技術(shù)了。JVM會(huì)通過(guò)逃逸分析技術(shù),對(duì)于逃不出方法的對(duì)象,會(huì)讓其在??臻g上進(jìn)行分配。

逃逸分析技術(shù):英文稱為 Escape Analysis,是目前JVM中比較前沿的一種優(yōu)化技術(shù),與類型繼承關(guān)系分析一樣,并不是直接優(yōu)化代碼的手段,而是為其他優(yōu)化措施提供依據(jù)的分析技術(shù)。

基本原理:分析對(duì)象動(dòng)態(tài)作用域,當(dāng)一個(gè)對(duì)象在方法里面被定義后,它可能被外部方法所引用,例如作為調(diào)用參數(shù)傳遞到其他方法中,這種行為被稱為方法逃逸;當(dāng)一個(gè)對(duì)象被外部線程訪問(wèn)到時(shí),比如賦值給可以在其他線程中訪問(wèn)的實(shí)例變量,這種行為稱為線程逃逸。從不逃逸、方法逃逸到線程逃逸,稱為對(duì)象由低到高的不同程度的逃逸。

JVM對(duì)象為什么一定在堆中分配

 方法逃逸

根據(jù)對(duì)象的逃逸程度來(lái)選擇采用不同的優(yōu)化方案,針對(duì)逃逸程度有三種優(yōu)化方案:

  • 棧上分配(Stack Allocations):如果能夠確定一個(gè)對(duì)象不會(huì)逃逸出線程之外,可以讓該對(duì)象在??臻g上進(jìn)行分配,對(duì)象所占用的內(nèi)存空間就會(huì)隨著棧幀出棧而銷毀。這樣做的好處就是減少資源消耗,對(duì)于JVM來(lái)說(shuō),對(duì)垃圾對(duì)象進(jìn)行標(biāo)記以及回收過(guò)程,都會(huì)消耗很多的資源,利用棧來(lái)分配會(huì)減少JVM標(biāo)記回收對(duì)象的數(shù)量,減輕回收壓力。

棧上分配支持方法逃逸,但不能支持線程逃逸,也就是說(shuō),對(duì)于逃不出方法的對(duì)象才能在棧中進(jìn)行分配

  • 標(biāo)量替換(Scalar Replacement):標(biāo)量,即一個(gè)已經(jīng)無(wú)法在分解成更小的數(shù)據(jù)的數(shù)據(jù),比如JVM中原始數(shù)據(jù)類型(int,long等);如果一個(gè)數(shù)據(jù)可以繼續(xù)分解,則稱為聚合量,Java的對(duì)象就是典型的聚合量。把一個(gè)對(duì)象拆散,根據(jù)程序的訪問(wèn)情況,將其用到的成員變量恢復(fù)成為原始類型來(lái)訪問(wèn),稱為標(biāo)量替換。若對(duì)象可以不被方法外部訪問(wèn)且不會(huì)被拆散,則可以不創(chuàng)建對(duì)象,直接創(chuàng)建它的成員變量。

不允許對(duì)象逃逸出方法范圍

JVM對(duì)象為什么一定在堆中分配

標(biāo)量替換

  • 同步消除:如果一個(gè)變量不會(huì)逃逸出線程之外,無(wú)法被其他線程訪問(wèn)到,則可以不用進(jìn)行同步措施。即可以消除掉對(duì)該變量的同步操作。不會(huì)產(chǎn)生線程安全問(wèn)題。

逃逸分析技術(shù)存在的問(wèn)題:

  • 到目前為止,該技術(shù)還未發(fā)展成熟,仍有很大的改進(jìn)余地

  • 逃逸分析的成本非常高,甚至不能保證逃逸分析帶來(lái)的性能收益會(huì)高于它的消耗

逃逸分析JVM參數(shù)設(shè)置:

  • -XX:+DoEscapeAnalysis 開啟逃逸分析

  • -XX:+PrintEscapeAnalysis 查看逃逸分析

  • -XX:+EliminateAllocations 開啟標(biāo)量替換

  • +XX:+EliminateLocks 開啟同步消除

  • -XX:+PrintEliminateAllocation 查看標(biāo)量替換

到此,關(guān)于“JVM對(duì)象為什么一定在堆中分配”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

jvm
AI