女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Java所承諾的自動內(nèi)存管理

存儲界 ? 來源:未知 ? 作者:李倩 ? 2018-04-29 15:16 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

Java所承諾的自動內(nèi)存管理主要是針對對象內(nèi)存的回收和對象內(nèi)存的分配。

在Java虛擬機的五塊內(nèi)存空間中,程序計數(shù)器、Java虛擬機棧、本地方法棧內(nèi)存的分配和回收都具有確定性,一般在編譯階段就能確定需要分配的內(nèi)存大小,并且由于都是線程私有,因此它們的內(nèi)存空間都隨著線程的創(chuàng)建而創(chuàng)建,線程的結(jié)束而回收。也就是這三個區(qū)域的內(nèi)存分配和回收都具有確定性,垃圾回收器不需要在這里花費太大的精力。

而Java虛擬機中的方法區(qū)因為是用來存儲類信息、常量、靜態(tài)變量,這些數(shù)據(jù)的變動性較小,因此不是Java內(nèi)存管理重點需要關(guān)注的區(qū)域。

而對于堆,所有線程共享,所有的對象都需要在堆中創(chuàng)建和回收。雖然每個對象的大小在類加載的時候就能確定,但對象的數(shù)量只有在程序運行期間才能確定,因此堆中內(nèi)存的分配具有較大的不確定性。此外,對象的生命周期長短不一,因此需要針對不同生命周期的對象采用不同的內(nèi)存回收算法,增加了內(nèi)存回收的復(fù)雜性。

綜上所述:Java自動內(nèi)存管理最核心的功能是堆內(nèi)存中對象的分配與回收。

對象優(yōu)先在Eden區(qū)中分配

目前主流的垃圾收集器都會采用分代回收算法,因此需要將堆內(nèi)存分為新生代和老年代。

在新生代中為了防止內(nèi)存碎片問題,因此垃圾收集器一般都選用“復(fù)制”算法。因此,堆內(nèi)存的新生代被進一步分為:Eden區(qū)+Survior1區(qū)+Survior2區(qū)。

每次創(chuàng)建對象時,首先會在Eden區(qū)中分配。

若Eden區(qū)已滿,則在Survior1區(qū)中分配。

若Eden區(qū)+Survior1區(qū)剩余內(nèi)存太少,導(dǎo)致對象無法放入該區(qū)域時,就會啟用“分配擔保”,將當前Eden區(qū)+Survior1區(qū)中的對象轉(zhuǎn)移到老年代中,然后再將新對象存入Eden區(qū)。

大對象直接進入老年代

所謂“大對象”就是指一個占用大量連續(xù)存儲空間的對象,如數(shù)組。

當發(fā)現(xiàn)一個大對象在Eden區(qū)+Survior1區(qū)中存不下的時候就需要分配擔保機制把當前Eden區(qū)+Survior1區(qū)的所有對象都復(fù)制到老年代中去。

我們知道,一個大對象能夠存入Eden區(qū)+Survior1區(qū)的概率比較小,發(fā)生分配擔保的概率比較大,而分配擔保需要涉及到大量的復(fù)制,就會造成效率低下。

因此,對于大對象我們直接把他放到老年代中去,從而就能避免大量的復(fù)制操作。

那么,什么樣的對象才是“大對象”呢?

通過-XX:PretrnureSizeThreshold參數(shù)設(shè)置大對象

該參數(shù)用于設(shè)置大小超過該參數(shù)的對象被認為是“大對象”,直接進入老年代。

注意:該參數(shù)只對Serial和ParNew收集器有效。

生命周期較長的對象進入老年代

老年代用于存儲生命周期較長的對象,那么我們?nèi)绾闻袛嘁粋€對象的年齡呢?

新生代中的每個對象都有一個年齡計數(shù)器,當新生代發(fā)生一次MinorGC后,存活下來的對象的年齡就加一,當年齡超過一定值時,就將超過該值的所有對象轉(zhuǎn)移到老年代中去。

使用-XXMaxTenuringThreshold設(shè)置新生代的最大年齡

設(shè)置該參數(shù)后,只要超過該參數(shù)的新生代對象都會被轉(zhuǎn)移到老年代中去。

相同年齡的對象內(nèi)存超過Survior內(nèi)存一半的對象進入老年代

如果當前新生代的Survior中,年齡相同的對象的內(nèi)存空間總和超過了Survior內(nèi)存空間的一半,那么所有年齡相同的對象和超過該年齡的對象都被轉(zhuǎn)移到老年代中去。無需等到對象的年齡超過MaxTenuringThreshold才被轉(zhuǎn)移到老年代中去。

“分配擔保”策略詳解

當垃圾收集器準備要在新生代發(fā)起一次MinorGC時,首先會檢查“老年代中最大的連續(xù)空閑區(qū)域的大小 是否大于 新生代中所有對象的大小?”,也就是老年代中目前能夠?qū)⑿律兴袑ο笕垦b下?

若老年代能夠裝下新生代中所有的對象,那么此時進行MinorGC沒有任何風險,然后就進行MinorGC。

若老年代無法裝下新生代中所有的對象,那么此時進行MinorGC是有風險的,垃圾收集器會進行一次預(yù)測:根據(jù)以往MinorGC過后存活對象的平均數(shù)來預(yù)測這次MinorGC后存活對象的平均數(shù)。

如果以往存活對象的平均數(shù)小于當前老年代最大的連續(xù)空閑空間,那么就進行MinorGC,雖然此次MinorGC是有風險的。

如果以往存活對象的平均數(shù)大于當前老年代最大的連續(xù)空閑空間,那么就對老年代進行一次Full GC,通過清除老年代中廢棄數(shù)據(jù)來擴大老年代空閑空間,以便給新生代作擔保。

這個過程就是分配擔保。

注意:

1. 分配擔保是老年代為新生代作擔保;

2. 新生代中使用“復(fù)制”算法實現(xiàn)垃圾回收,老年代中使用“標記-清除”或“標記-整理”算法實現(xiàn)垃圾回收,只有使用“復(fù)制”算法的區(qū)域才需要分配擔保,因此新生代需要分配擔保,而老年代不需要分配擔保。

名詞解釋:

GC:垃圾收集器

Minor GC:新生代GC,指發(fā)生在新生代的垃圾收集動作,所有的Minor GC都會觸發(fā)全世界的暫停(stop-the-world),停止應(yīng)用程序的線程,不過這個過程非常短暫。

Major GC/Full GC:老年代GC,指發(fā)生在老年代的GC。

JVM:Java Virtual Machine(Java虛擬機)的縮寫。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 內(nèi)存
    +關(guān)注

    關(guān)注

    8

    文章

    3122

    瀏覽量

    75248
  • JAVA
    +關(guān)注

    關(guān)注

    20

    文章

    2989

    瀏覽量

    109576

原文標題:JVM學(xué)習(xí),對象內(nèi)存的分配策略

文章出處:【微信號:cunchujie,微信公眾號:存儲界】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點推薦

    Java程序內(nèi)存低效使用問題的分析

    Java程序內(nèi)存的低效使用是導(dǎo)致其性能問題的主要因素。該文分析了泄漏對象、蚍蜉對象和空閑對象3類導(dǎo)致內(nèi)存低效使用的情況,探討解決上述問題的方法,并提出構(gòu)造對象行為模式
    發(fā)表于 04-09 09:39 ?12次下載

    java線程內(nèi)存模型

    一、Java內(nèi)存模型 按照官方的說法:Java 虛擬機具有一個堆,堆是運行時數(shù)據(jù)區(qū)域,所有類實例和數(shù)組的內(nèi)存均從此處分配。 JVM主要管理
    發(fā)表于 09-27 10:55 ?0次下載
    <b class='flag-5'>java</b>線程<b class='flag-5'>內(nèi)存</b>模型

    實例分析內(nèi)存回收機制在java中的應(yīng)用

    Java中,它的內(nèi)存管理包括兩方面:內(nèi)存分配(創(chuàng)建Java對象的時候)和內(nèi)存回收,這兩方面工作
    發(fā)表于 09-27 15:10 ?0次下載
    實例分析<b class='flag-5'>內(nèi)存</b>回收機制在<b class='flag-5'>java</b>中的應(yīng)用

    Java內(nèi)存模型及原理分析

    一、Java內(nèi)存模型 按照官方的說法:Java 虛擬機具有一個堆,堆是運行時數(shù)據(jù)區(qū)域,所有類實例和數(shù)組的內(nèi)存均從此處分配。 JVM主要管理
    發(fā)表于 09-28 11:49 ?0次下載
    <b class='flag-5'>Java</b><b class='flag-5'>內(nèi)存</b>模型及原理分析

    Java內(nèi)存區(qū)域分配、Java虛擬機棧、對象的訪問方式和GC

    對于Java程序員來說,在虛擬機的自動內(nèi)存管理機制的幫助下,不再需要為每一個new操作去寫配對的delete/free代碼,而且不容易出現(xiàn) 內(nèi)存
    發(fā)表于 12-11 16:28 ?2397次閱讀
    <b class='flag-5'>Java</b><b class='flag-5'>內(nèi)存</b>區(qū)域分配、<b class='flag-5'>Java</b>虛擬機棧、對象的訪問方式和GC

    Android內(nèi)存泄漏問題如何優(yōu)化?

    作者:無名之輩FTER 來源:CSDN博客 眾所周知,Java因其擁有獨特的虛擬機(JVM)設(shè)計,使其成為一門跨平臺、內(nèi)存自動管理的高級開發(fā)語言。所謂跨平臺,即一次編譯,多次運行,從而
    的頭像 發(fā)表于 09-11 15:55 ?2017次閱讀

    詳解Java虛擬機的JVM內(nèi)存布局

    JVM內(nèi)存布局規(guī)定了Java在運行過程中內(nèi)存申請、分配、管理的策略,保證了JVM的穩(wěn)定高效運行。不同的JVM對于內(nèi)存的劃分方式和
    的頭像 發(fā)表于 07-13 09:52 ?696次閱讀
    詳解<b class='flag-5'>Java</b>虛擬機的JVM<b class='flag-5'>內(nèi)存</b>布局

    java內(nèi)存溢出的幾種原因和解決辦法

    Java是一種使用垃圾回收機制的編程語言,由于自動內(nèi)存管理機制的存在,Java程序中發(fā)生內(nèi)存溢出
    的頭像 發(fā)表于 11-23 14:44 ?6830次閱讀

    java內(nèi)存溢出排查方法

    Java內(nèi)存溢出(Memory overflow)是指Java虛擬機(JVM)中的堆內(nèi)存無法滿足對象分配的需求,導(dǎo)致程序拋出OutOfMemoryError異常。
    的頭像 發(fā)表于 11-23 14:46 ?3922次閱讀

    如何查看java程序的內(nèi)存分布

    。 程序計數(shù)器: 程序計數(shù)器是一塊較小的內(nèi)存空間,它的作用是指示當前線程執(zhí)行的字節(jié)碼指令的行號。在多線程環(huán)境下,每個線程都有一個獨立的程序計數(shù)器,用于記錄當前線程執(zhí)行的字節(jié)碼指令。 Java虛擬機棧:
    的頭像 發(fā)表于 11-23 14:47 ?1371次閱讀

    jvm運行時內(nèi)存區(qū)域劃分

    JVM是Java Virtual Machine(Java虛擬機)的縮寫,它是Java編程語言的運行環(huán)境。JVM的主要功能是將Java源代碼轉(zhuǎn)換為機器代碼,并且在運行時
    的頭像 發(fā)表于 12-05 14:08 ?736次閱讀

    jvm管理內(nèi)存包括哪幾個運行時數(shù)據(jù)內(nèi)存

    JVM(Java虛擬機)是Java程序的運行環(huán)境,它提供了內(nèi)存管理機制來管理Java程序所需的運
    的頭像 發(fā)表于 12-05 14:09 ?829次閱讀

    jvm內(nèi)存區(qū)域由哪幾部分組成

    。下面將詳細介紹這些部分。 堆內(nèi)存(Heap Memory):堆內(nèi)存是JVM中最大的一塊內(nèi)存區(qū)域,用來存儲對象實例和數(shù)組對象。堆內(nèi)存被所有線程
    的頭像 發(fā)表于 12-05 14:10 ?1159次閱讀

    java虛擬機內(nèi)存包括遠空間內(nèi)存

    詳細介紹JVM內(nèi)存的各個部分及其作用。 Java堆(Heap) Java堆是JVM管理的最大一塊內(nèi)存區(qū)域,用于存放
    的頭像 發(fā)表于 12-05 14:15 ?605次閱讀

    深入理解Java 8內(nèi)存管理機制及故障排查實戰(zhàn)指南

    Java自動內(nèi)存管理機制是由 JVM 中的垃圾收集器來實現(xiàn)的,垃圾收集器會定期掃描堆內(nèi)存中的對象,檢測并清除不再使用的對象,以釋放
    的頭像 發(fā)表于 04-04 08:10 ?1276次閱讀
    深入理解<b class='flag-5'>Java</b> 8<b class='flag-5'>內(nèi)存</b><b class='flag-5'>管理</b>機制及故障排查實戰(zhàn)指南