www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 公眾號精選 > 架構師社區(qū)
[導讀]學過 JVM的人都知道在JVM中在執(zhí)行Java程序的過程中會把JVM管理的內存進行劃分,叫做 運行時數據區(qū)。 JVM中管理的內存主要分為以下五個部分: 方法區(qū)(Method Area): Java堆(Heap):Java堆是JVM管理內存中最大的一塊區(qū)域,幾乎所有的Java對象的內存都在這


學過 JVM的人都知道在JVM中在執(zhí)行Java程序的過程中會把JVM管理的內存進行劃分,叫做 運行時數據區(qū)。

JVM中管理的內存主要分為以下五個部分:

  1. 方法區(qū)Method Area):

  2. Java堆Heap):Java堆是JVM管理內存中最大的一塊區(qū)域,幾乎所有的Java對象的內存都在這里分配,此區(qū)域也是GC最活躍的區(qū)域。

  3. 虛擬機棧VM Stack):此區(qū)域就是我們通常所說的“”,當線程執(zhí)行方法時會在此區(qū)域創(chuàng)建一個棧幀,用于儲存局部變量表、動態(tài)鏈接、方法出口等信息。

  4. 本地方法棧Native Method Stack):本地方法棧虛擬機棧類似,只不過本地方法棧執(zhí)行的是Native方法服務。

  5. 程序計數器Program Counter Register):是當前線程執(zhí)行字節(jié)碼的行號指令器,是線程私有的。

當執(zhí)行一個Java方法,程序計數器記錄的是JVM正在執(zhí)行的字節(jié)碼指令,若是執(zhí)行的是本地方法,程序計數器為空。

你的對象在哪里?長什么樣?我?guī)闳タ匆豢? >
   </figure>
   <br>這五個部分都有自己的功能,有些區(qū)域是線程私有的,會跟隨著線程的創(chuàng)建和銷毀,有些區(qū)域是跟隨進程的啟動而存在,各自承擔著自己的職責。
   <p style=在方法區(qū)中還有一塊區(qū)域就是常量池,很多人叫它為永生代 PermGen(JDK 1.7的說法)。

隨著JDK8的到來,JVM不再有PermGen。但類的元數據信息還在,不再是存儲在連續(xù)的堆空間上,而是移動到叫做Metaspace(元空間)的本地內存(Native memory)中。

我們知道當我們執(zhí)行創(chuàng)建對象的時候,就會初始化對象的屬性信息,例如執(zhí)行如下的代碼:

public class TestObj {

    private int n=1;

    public static void main(String[] args) throws Exception {

        TestObj obj =new TestObj();

    }
}

該代碼非常的簡單,在main方法中執(zhí)行TestObj obj =new TestObj()就會初始化該對象的成員變量n為1,我們都知道這個過程叫做初始化,在初始化的時候也會進行半始化。

那么什么叫做半初始化呢?

半初始化就是當一個成員變量還未初始化為它真正的值,會先初始化為它默認是的值,例如int會先初始化為0,boolean會先初始化為false等。

對于半初始化,真正的講清楚要從執(zhí)行的字節(jié)碼指令分析,下面我們通過字節(jié)碼指令進行深入的分析,一個對象的初始化過程。

具體在idea中查看字節(jié)碼指令的方法可以自行百度,這個不難,通過idea中可以查看上面代碼執(zhí)行的指令,如下所示:

你的對象在哪里?長什么樣?我?guī)闳タ匆豢? >
   </figure>
   <br>在上面mian方法中執(zhí)行完,也就是對應這五條指令,如下所示:
  </section>
  <section style=
  1. new指令:表示首先在堆中申請一塊內存,此時堆中的內存中存儲著該對象屬性n的半初始化狀態(tài)值n=0。

  2. dup指令:表示復制引用。

  3. invokespecial指令:表示調用對象的初始化方法,后面對應的注釋Method " " ,此時屬性值n才會被初始化為1。

  4. astore_1指令:此時會將TestObj obj =new TestObj()的引用obj 與該堆中的對象建立連接。

  5. return指令:執(zhí)行完最后返回。

從上面的指令中分析可以看出,當創(chuàng)建一個對象的時候,主要分為以下三個步驟,執(zhí)行的原理圖如下:

你的對象在哪里?長什么樣?我?guī)闳タ匆豢? >
   </figure>
   <br>
   <strong style=了解完對象的半初始化,那么什么又是對象分配?

說到JVM中的對象分配,我們得從對象在JVM中執(zhí)行new指令后開始講起。客觀且慢,請聽我詳細道來。

在JVM中當遇到一條new指令時,會首先檢查這條指令的參數是否在常量池中能定位到一個類的符號引用,若是定位不到,就表示沒有被加載、解析和初始化過,就會先執(zhí)行加載該類。

JVM中加載類信息的詳細過程,請參考這一篇文章[面試官:你知道java類是怎么跑起來的嗎?問的我一臉懵]。

若是存在該符號引用表示之前已經加載過該類信息,接下來就直接執(zhí)行在堆中進行對象內存的分配。

但是隨著JVM的發(fā)展,JIT編譯器的出現,所有的對象分配在堆中就不那么絕對了,當創(chuàng)建對象為對象分配內存時,也會嘗試在棧上分配,在JVM書籍中的描述如下所示:

你的對象在哪里?長什么樣?我?guī)闳タ匆豢? >
   </figure>
   <br>
   <strong style=那么什么是逃逸技術? 每個線程執(zhí)行方法都會創(chuàng)建一個棧幀,該棧幀用于存儲方法的局部變量,當一個變量不會在其他方法中使用到,只在該方法中使用,就不會逃逸。

什么又是變量替換呢? 標量替換就是創(chuàng)建一個對象的時候,直接以對象的屬性進行入棧存儲,方法結束后直接彈棧結束,不會有GC的介入。

因此,在棧上分配是對JVM的一種優(yōu)化措施,減少了GC的活動,提高了Java虛擬機的執(zhí)行效率。

當對象執(zhí)行在堆上進行內存分配的時候,為了防止多線程分配內存存在混亂的情況,通常在多線程的時候對對象內存的分配    有以下兩種方案進行解決:

  1. 對分配內存的動作進行同步,但是同步的的操作太消耗性能,大大降低了JVM的性能。

  2. 對堆內存為每一個線程劃分一塊本地線程分配緩沖TLAB),是線程私有的,這樣每一個線程只需要在自己的TLAB中進行分配即可,就不用進行同步,也能達到線程安全的目的:

那么當一個對象在堆中分配完一個內存后,對象在堆中又是怎么存在的呢?

客觀不急請聽我慢慢道來,當對象在堆中進行完內存分配后,一個普通對象在堆中以如下圖的形式存在:

你的對象在哪里?長什么樣?我?guī)闳タ匆豢? >
   </figure>
   <ol style=
  • markword:存儲的是鎖信息、對象的年齡信息等。

  • class pointer:類型指針指向該對象class類型。

  • instance data:實例數據,儲存對象實例的數據值。

  • padding:對其若是該對象的大小不能被8字節(jié)整除,就會自動補齊為8字節(jié)的整數倍。

  • 那么對象都已經存在堆中了,我們又是怎么訪問該對象的?

    若要訪問堆中已經存在的對象,有以下兩種方式:

    (1) 句柄的方式:會在堆中劃分一塊下的內存作為句柄池,對象的引用不會直接存儲數據的地址,而是指向句柄池的指針,由句柄池的指針存儲數據的地址。

    句柄池的方式,由于對象引用不會直接指向數據的地址,這樣當GC進行回收垃圾的時候,移動對象,對象的地址改變了就不用改變reference的本身內容。

    這個也是句柄訪問方式的唯一優(yōu)點,具體句柄訪問方式的原理圖如下所示:

    你的對象在哪里?長什么樣?我?guī)闳タ匆豢? >
   </figure>
   <p style=(2) 直接方式:直接方式是reference直接指向數據的,這樣減少了一次指針的定位,速度快,直接訪問的方式原理圖如下:

    你的對象在哪里?長什么樣?我?guī)闳タ匆豢? >
   </figure>
   <blockquote style=

    注意: 在HostSpot的源碼實現中,使用的是第二種直接訪問的方式

    特別推薦一個分享架構+算法的優(yōu)質內容,還沒關注的小伙伴,可以長按關注一下:

    你的對象在哪里?長什么樣?我?guī)闳タ匆豢? ></p><pre ng-bind-html=

    長按訂閱更多精彩▼

    你的對象在哪里?長什么樣?我?guī)闳タ匆豢? ></p><p style=如有收獲,點個在看,誠摯感謝

    免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

    本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
    換一批
    延伸閱讀

    9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

    關鍵字: 阿維塔 塞力斯 華為

    加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

    關鍵字: AWS AN BSP 數字化

    倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

    關鍵字: 汽車 人工智能 智能驅動 BSP

    北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

    關鍵字: 亞馬遜 解密 控制平面 BSP

    8月30日消息,據媒體報道,騰訊和網易近期正在縮減他們對日本游戲市場的投資。

    關鍵字: 騰訊 編碼器 CPU

    8月28日消息,今天上午,2024中國國際大數據產業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

    關鍵字: 華為 12nm EDA 半導體

    8月28日消息,在2024中國國際大數據產業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數字世界的話語權最終是由生態(tài)的繁榮決定的。

    關鍵字: 華為 12nm 手機 衛(wèi)星通信

    要點: 有效應對環(huán)境變化,經營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

    關鍵字: 通信 BSP 電信運營商 數字經濟

    北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現場 NVI技術創(chuàng)新聯(lián)...

    關鍵字: VI 傳輸協(xié)議 音頻 BSP

    北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

    關鍵字: BSP 信息技術
    關閉
    關閉