精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

JVM源碼分析之堆外內(nèi)存完全解讀

開發(fā) 開發(fā)工具
DirectByteBuffer在創(chuàng)建的時候會通過Unsafe的native方法來直接使用malloc分配一塊內(nèi)存,這塊內(nèi)存是heap之外的,那么自然也不會對gc造成什么影響(System.gc除外),因為gc耗時的操作主要是操作heap之內(nèi)的對象,對這塊內(nèi)存的操作也是直接通過Unsafe的native方法來操作的,相當(dāng)于DirectByteBuffer僅僅是一個殼,還有我們通信過程中如果數(shù)據(jù)是在Heap里的,最終也還是會copy一份到堆外,然后再進行發(fā)送,所以為什么不直接使用堆外內(nèi)存呢。

[[181296]]

概述

廣義的堆外內(nèi)存

說到堆外內(nèi)存,那大家肯定想到堆內(nèi)內(nèi)存,這也是我們大家接觸最多的,我們在jvm參數(shù)里通常設(shè)置-Xmx來指定我們的堆的***值,不過這還不是我們理解的Java堆,-Xmx的值是新生代和老生代的和的***值,我們在jvm參數(shù)里通常還會加一個參數(shù)-XX:MaxPermSize來指定持久代的***值,那么我們認(rèn)識的Java堆的***值其實是-Xmx和-XX:MaxPermSize的總和,在分代算法下,新生代,老生代和持久代是連續(xù)的虛擬地址,因為它們是一起分配的,那么剩下的都可以認(rèn)為是堆外內(nèi)存(廣義的)了,這些包括了jvm本身在運行過程中分配的內(nèi)存,codecache,jni里分配的內(nèi)存,DirectByteBuffer分配的內(nèi)存等等

狹義的堆外內(nèi)存

而作為java開發(fā)者,我們常說的堆外內(nèi)存溢出了,其實是狹義的堆外內(nèi)存,這個主要是指java.nio.DirectByteBuffer在創(chuàng)建的時候分配內(nèi)存,我們這篇文章里也主要是講狹義的堆外內(nèi)存,因為它和我們平時碰到的問題比較密切

JDK/JVM里DirectByteBuffer的實現(xiàn)

DirectByteBuffer通常用在通信過程中做緩沖池,在mina,netty等nio框架中屢見不鮮,先來看看JDK里的實現(xiàn):

通過上面的構(gòu)造函數(shù)我們知道,真正的內(nèi)存分配是使用的Bits.reserveMemory方法

通過上面的代碼我們知道可以通過-XX:MaxDirectMemorySize來指定***的堆外內(nèi)存,那么我們首先引入兩個問題

堆外內(nèi)存默認(rèn)是多大

為什么要主動調(diào)用System.gc()

  • 堆外內(nèi)存默認(rèn)是多大
  • 如果我們沒有通過-XX:MaxDirectMemorySize來指定***的堆外內(nèi)存,那么默認(rèn)的***堆外內(nèi)存是多少呢,我們還是通過代碼來分析

上面的代碼里我們看到調(diào)用了sun.misc.VM.maxDirectMemory()

看到上面的代碼之后是不是誤以為默認(rèn)的***值是64M?其實不是的,說到這個值得從java.lang.System這個類的初始化說起

上面這個方法在jvm啟動的時候?qū)ystem這個類做初始化的時候執(zhí)行的,因此執(zhí)行時間非常早,我們看到里面調(diào)用了sun.misc.VM.saveAndRemoveProperties(props):

如果我們通過-Dsun.nio.MaxDirectMemorySize指定了這個屬性,只要它不等于-1,那效果和加了-XX:MaxDirectMemorySize一樣的,如果兩個參數(shù)都沒指定,那么***堆外內(nèi)存的值來自于directMemory = Runtime.getRuntime().maxMemory(),這是一個native方法

其中在我們使用CMS GC的情況下的實現(xiàn)如下,其實是新生代的***值-一個survivor的大小+老生代的***值,也就是我們設(shè)置的-Xmx的值里除去一個survivor的大小就是默認(rèn)的堆外內(nèi)存的大小了

為什么要主動調(diào)用System.gc

既然要調(diào)用System.gc,那肯定是想通過觸發(fā)一次gc操作來回收堆外內(nèi)存,不過我想先說的是堆外內(nèi)存不會對gc造成什么影響(這里的System.gc除外),但是堆外內(nèi)存的回收其實依賴于我們的gc機制,首先我們要知道在java層面和我們在堆外分配的這塊內(nèi)存關(guān)聯(lián)的只有與之關(guān)聯(lián)的DirectByteBuffer對象了,它記錄了這塊內(nèi)存的基地址以及大小,那么既然和gc也有關(guān),那就是gc能通過操作DirectByteBuffer對象來間接操作對應(yīng)的堆外內(nèi)存了。DirectByteBuffer對象在創(chuàng)建的時候關(guān)聯(lián)了一個PhantomReference,說到PhantomReference它其實主要是用來跟蹤對象何時被回收的,它不能影響gc決策,但是gc過程中如果發(fā)現(xiàn)某個對象除了只有PhantomReference引用它之外,并沒有其他的地方引用它了,那將會把這個引用放到j(luò)ava.lang.ref.Reference.pending隊列里,在gc完畢的時候通知ReferenceHandler這個守護線程去執(zhí)行一些后置處理,而DirectByteBuffer關(guān)聯(lián)的PhantomReference是PhantomReference的一個子類,在最終的處理里會通過Unsafe的free接口來釋放DirectByteBuffer對應(yīng)的堆外內(nèi)存塊

JDK里ReferenceHandler的實現(xiàn):

可見如果pending為空的時候,會通過lock.wait()一直等在那里,其中喚醒的動作是在jvm里做的,當(dāng)gc完成之后會調(diào)用如下的方法VM_GC_Operation::doit_epilogue(),在方法末尾會調(diào)用lock的notify操作,至于pending隊列什么時候?qū)⒁梅胚M去的,其實是在gc的引用處理邏輯中放進去的,針對引用的處理后面可以專門寫篇文章來介紹

對于System.gc的實現(xiàn),之前寫了一篇文章來重點介紹,JVM源碼分析之SystemGC完全解讀,它會對新生代的老生代都會進行內(nèi)存回收,這樣會比較徹底地回收DirectByteBuffer對象以及他們關(guān)聯(lián)的堆外內(nèi)存,我們dump內(nèi)存發(fā)現(xiàn)DirectByteBuffer對象本身其實是很小的,但是它后面可能關(guān)聯(lián)了一個非常大的堆外內(nèi)存,因此我們通常稱之為『冰山對象』,我們做ygc的時候會將新生代里的不可達的DirectByteBuffer對象及其堆外內(nèi)存回收了,但是無法對old里的DirectByteBuffer對象及其堆外內(nèi)存進行回收,這也是我們通常碰到的***的問題,如果有大量的DirectByteBuffer對象移到了old,但是又一直沒有做cms gc或者full gc,而只進行ygc,那么我們的物理內(nèi)存可能被慢慢耗光,但是我們還不知道發(fā)生了什么,因為heap明明剩余的內(nèi)存還很多(前提是我們禁用了System.gc)。

為什么要使用堆外內(nèi)存

DirectByteBuffer在創(chuàng)建的時候會通過Unsafe的native方法來直接使用malloc分配一塊內(nèi)存,這塊內(nèi)存是heap之外的,那么自然也不會對gc造成什么影響(System.gc除外),因為gc耗時的操作主要是操作heap之內(nèi)的對象,對這塊內(nèi)存的操作也是直接通過Unsafe的native方法來操作的,相當(dāng)于DirectByteBuffer僅僅是一個殼,還有我們通信過程中如果數(shù)據(jù)是在Heap里的,最終也還是會copy一份到堆外,然后再進行發(fā)送,所以為什么不直接使用堆外內(nèi)存呢。對于需要頻繁操作的內(nèi)存,并且僅僅是臨時存在一會的,都建議使用堆外內(nèi)存,并且做成緩沖池,不斷循環(huán)利用這塊內(nèi)存。

為什么不能大面積使用堆外內(nèi)存

如果我們大面積使用堆外內(nèi)存并且沒有限制,那遲早會導(dǎo)致內(nèi)存溢出,畢竟程序是跑在一臺資源受限的機器上,因為這塊內(nèi)存的回收不是你直接能控制的,當(dāng)然你可以通過別的一些途徑,比如反射,直接使用Unsafe接口等,但是這些務(wù)必給你帶來了一些煩惱,Java與生俱來的優(yōu)勢被你完全拋棄了—開發(fā)不需要關(guān)注內(nèi)存的回收,由gc算法自動去實現(xiàn)。另外上面的gc機制與堆外內(nèi)存的關(guān)系也說了,如果一直觸發(fā)不了cms gc或者full gc,那么后果可能很嚴(yán)重。

【本文是51CTO專欄作者李嘉鵬的原創(chuàng)文章,轉(zhuǎn)載請通過微信公眾號(你假笨,id:lovestblog)聯(lián)系作者本人獲取授權(quán)】

戳這里,看該作者更多好文

責(zé)任編輯:武曉燕 來源: 你假笨
相關(guān)推薦

2017-01-12 14:52:03

JVMFinalRefere源碼

2020-05-26 18:50:46

JVMAttachJava

2017-01-11 14:19:26

JVM源碼All

2022-07-03 20:31:59

JVMJava虛擬機

2019-02-26 14:33:22

JVM內(nèi)存虛擬機

2024-10-31 09:24:42

2022-12-26 14:41:38

Linux內(nèi)存

2020-08-27 21:36:50

JVM內(nèi)存泄漏

2017-02-27 11:48:58

JVM源碼分析Java

2020-07-21 14:19:18

JVM編程語言

2018-04-17 14:41:41

Java堆內(nèi)存溢出

2022-11-09 17:10:47

JVM內(nèi)存區(qū)域

2009-07-14 18:26:49

MyEclipse內(nèi)存

2015-08-06 14:54:50

JavaScript分析工具OneHeap

2024-05-27 00:03:00

Java數(shù)據(jù)JVM

2022-04-29 08:05:06

內(nèi)存堆外GC

2022-04-15 07:51:12

off-heap堆外內(nèi)存JVM

2022-09-21 08:39:52

堆外內(nèi)存泄露內(nèi)存分布

2011-08-16 09:34:34

Nginx

2021-03-11 08:10:48

JVM對象的創(chuàng)建School
點贊
收藏

51CTO技術(shù)棧公眾號

日av在线播放中文不卡| 亚洲国产精品久久久久| 影音欧美亚洲| 亚洲国产一二三区| 麻豆精品91| 久久精品国产精品亚洲| 日韩av手机在线播放| 欧美精品高清| 一区二区三区不卡视频| 久久人人97超碰人人澡爱香蕉| 69av视频在线观看| 欧美视频网站| 中文国产亚洲喷潮| 插我舔内射18免费视频| 成人午夜在线| 午夜欧美在线一二页| 伊人精品久久久久7777| 色婷婷av一区二区三| 美女精品自拍一二三四| 欧美极品少妇xxxxx| 精品无码人妻一区二区免费蜜桃 | 国产一区电影| 成人一区二区在线观看| 国产精品丝袜高跟| www.国产成人| 欧美精品一级| 日韩在线观看网址| 90岁老太婆乱淫| 成人福利一区| 日韩视频在线你懂得| 一区二区xxx| 中文字幕成在线观看| 一区二区欧美精品| 一区二区三区四区免费视频| 日产精品久久久久久久性色| 国产精品123区| 91精品免费久久久久久久久| 伊人久久久久久久久久久久 | 欧美中文字幕在线播放| 久草免费新视频| 91精品秘密在线观看| 中文日韩在线观看| 国产在线免费av| 免费观看久久av| 日韩精品一区二区三区第95| 图片区偷拍区小说区| 日韩中文字幕| 日韩一区二区电影在线| 天天做天天干天天操| 欧美午夜三级| 欧美情侣在线播放| 亚洲精品综合在线观看| 精品亚洲a∨| 欧美日韩国产系列| 色噜噜狠狠一区二区三区狼国成人| 精品福利在线| 欧美伦理视频网站| 一区二区三区四区毛片| 日韩成人精品一区二区三区| 欧美日韩色一区| 中文字幕 91| 久久久久毛片| 欧美一区二区三区的| 日本女人黄色片| 亚洲青青一区| 日韩一级大片在线| 在线播放av网址| 亚洲福利天堂| 一区二区三区四区在线观看视频| 国产又粗又黄又猛| 欧美电影《睫毛膏》| 久久精品国产99国产精品澳门| 久久久久久久久久网站| 欧美三级免费| 欧美又大粗又爽又黄大片视频| 无码人妻精品一区二区三区不卡| 日韩精品乱码av一区二区| 国产精品久久久久久久久久小说| 一级aaaa毛片| 国产很黄免费观看久久| 久久久久免费网| 啊v视频在线| 一区二区三区四区乱视频| av在线免费观看国产| 免费v片在线观看| 欧美视频在线一区二区三区 | 日韩精选在线观看| 国产一区二区三区久久久 | 日韩av观看网址| 一区二区视频免费观看| 粉嫩aⅴ一区二区三区四区| 精品无人乱码一区二区三区的优势| 久热av在线| 亚洲啪啪综合av一区二区三区| 无码 制服 丝袜 国产 另类| 日本欧美日韩| 日韩欧美不卡一区| 亚洲日本精品视频| 欧美日韩国产在线一区| 日本精品性网站在线观看| 国产精品区在线观看| 99热在这里有精品免费| 中文字幕一区二区三区5566| av中文字幕在线看| 欧美老年两性高潮| 欧美成人午夜精品免费| 亚洲成人一区| 国产精品a久久久久久| www.色亚洲| 亚洲国产成人午夜在线一区| av日韩一区二区三区| 青青国产精品| 亚洲热线99精品视频| 久久久国产精华液| 国产在线精品免费| 日本高清一区| 免费高潮视频95在线观看网站| 91精品国产麻豆国产自产在线 | 要久久爱电视剧全集完整观看 | 国产一区二区三区香蕉| 欧美日韩在线观看一区二区三区| 另类视频在线| 欧美一级一级性生活免费录像| аⅴ天堂中文在线网| 国产精品一级| 国产免费一区二区三区| 中文字幕伦理免费在线视频 | 国产精品入口免费视| 无码国产精品一区二区免费16| 亚洲摸摸操操av| 黄大色黄女片18第一次| 精品国产日韩欧美| 91精品国产高清自在线看超| 六月婷婷中文字幕| 亚洲精选视频免费看| 狠狠操狠狠干视频| 日本午夜一区| 国产成人在线精品| 男操女在线观看| 日韩欧美国产黄色| 黄色片视频免费观看| 在线欧美不卡| 国产精品一级久久久| 欧美性猛片xxxxx免费中国| 9191久久久久久久久久久| 久操视频在线观看免费| 热久久久久久久| 亚洲欧美日韩国产成人综合一二三区| 黄瓜视频成人app免费| 亚洲欧美一区二区三区四区 | 久久综合伊人| 欧美系列一区| 成人h在线观看| 色琪琪综合男人的天堂aⅴ视频| 欧美一级做a爰片免费视频| 国产亚洲一区字幕| 又色又爽又高潮免费视频国产| 中国av一区| 国产精品1234| 一区二区三区视频网站| 欧美精品vⅰdeose4hd| 欧美做爰啪啪xxxⅹ性| 国模少妇一区二区三区| 老司机av福利| 91午夜精品| 57pao成人国产永久免费| 飘雪影院手机免费高清版在线观看 | 欧美大胆成人| 最近2019中文字幕一页二页| 国产一区二区在线视频聊天| 亚洲免费观看高清在线观看| 97超碰成人在线| 欧美永久精品| 激情视频在线观看一区二区三区| 黄色在线网站噜噜噜| 亚洲视频电影图片偷拍一区| 最近国语视频在线观看免费播放| 国产精品久久久久aaaa| 波多野结衣网页| 亚洲免费大片| 亚洲一区二区免费视频软件合集| 国产精品igao视频网网址不卡日韩| 欧美激情欧美激情在线五月| 天堂成人在线| 91超碰这里只有精品国产| 久久精品国产亚洲AV无码男同| 久久综合狠狠综合久久综合88| 香蕉视频禁止18| 亚洲大片在线| 先锋影音欧美| 6080成人| 国产精品久久久久久久久粉嫩av| a篇片在线观看网站| 亚洲精品电影网| 亚洲一区中文字幕在线| 亚洲国产综合色| 萌白酱视频在线| av亚洲精华国产精华精华| 91极品尤物在线播放国产| 激情久久久久| 青少年xxxxx性开放hg| 男人的天堂久久| 91亚洲精品久久久| 都市激情亚洲综合| 欧美激情久久久久久| 国产一级片在线播放| 欧美成人激情免费网| 亚洲国产av一区二区三区| 夜夜嗨av一区二区三区中文字幕 | 一区二区三区精品视频在线| 精品人伦一区二区三电影| 国产电影一区二区三区| 99视频在线视频| 一本久道久久综合狠狠爱| 中日韩在线视频| 岛国精品一区二区| 精品激情国产视频| 四虎在线观看| 日韩你懂的在线播放| 国产天堂第一区| 亚洲成国产人片在线观看| 波多野结衣亚洲一区二区| 国产午夜久久久久| 久久精品综合视频| 成人深夜福利app| 一级片黄色免费| 蜜臀av国产精品久久久久| 日韩精品视频久久| 99国内精品| 青青草成人免费在线视频| 欧美高清日韩| 日韩精品一区二区三区电影| 成人在线免费观看网站| 欧美一区1区三区3区公司| 青青草原在线亚洲| 国产精品一区二区免费| 精品一区二区三区四区五区 | 亚洲国产精选| 国产精品美女久久久免费 | 色老综合老女人久久久| 国产午夜性春猛交ⅹxxx| 亚洲五码中文字幕| 国产在线精品观看| 亚洲成人激情综合网| 国产在线观看免费av| 亚洲高清视频在线| av大片免费观看| 欧美日韩一区二区在线播放| 国产微拍精品一区| 欧美性感美女h网站在线观看免费| 日韩av女优在线观看| 午夜精品福利久久久| 日韩成人一区二区三区| 欧美日韩激情美女| 久久久精品视频网站| 在线免费av一区| 亚洲精品一区二区二区| 欧美卡1卡2卡| 亚洲国产综合网| 亚洲精品国产成人| 嫩草在线播放| 中文字幕日韩欧美| 国产黄网站在线观看| 欧美国产亚洲视频| 深夜在线视频| 国产精品麻豆va在线播放| 国产精品亚洲一区二区在线观看| a级国产乱理论片在线观看99| 韩国精品福利一区二区三区| 蜜桃av噜噜一区二区三区| jvid福利在线一区二区| 无码人妻aⅴ一区二区三区日本| 国产真实久久| 欧美成人xxxxx| 精品在线播放午夜| 香港三日本8a三级少妇三级99| 久久这里只有精品6| 国产又黄又粗又猛又爽的| 亚洲国产日韩一级| 久久久久久不卡| 91精品国产麻豆国产自产在线| 神马久久久久久久久久| 亚洲视频在线免费观看| 成人高清免费在线| 青青在线视频一区二区三区| 欧美一级网址| 精品无码久久久久久久动漫| 91嫩草亚洲精品| 日韩欧美国产综合在线| 麻豆精品国产传媒mv男同 | 国产女人aaa级久久久级 | 成人综合网网址| 日韩欧美黄色| 日日噜噜夜夜狠狠久久丁香五月| 99视频一区| www.桃色.com| 久久日韩精品一区二区五区| 99久久婷婷国产综合| 色婷婷国产精品久久包臀| 国产美女明星三级做爰| 亚洲欧美中文日韩v在线观看| 国产成人l区| 国产精品高潮呻吟久久av黑人| 伊人精品久久| 亚洲欧洲免费无码| 亚洲免费影视| 特级特黄刘亦菲aaa级| 国产精品久久久99| 国产剧情在线视频| 精品精品欲导航| 日本在线观看| 国产成人精品久久二区二区| 成人精品毛片| 在线观看av的网址| 精品综合久久久久久8888| 人人人妻人人澡人人爽欧美一区| 亚洲国产毛片aaaaa无费看| 国产精品热久久| 日韩亚洲一区二区| 国产精品亚洲d| 麻豆av一区二区| 国产欧美精品久久| 久久久久国产免费| 亚洲天堂2016| 国产精品视频久久久久久| 亚洲日本中文字幕| 欧美电影免费看| 久久av一区二区| 亚洲高清毛片| 亚洲乱妇老熟女爽到高潮的片| ...av二区三区久久精品| 在线观看国产一区二区三区| 亚洲天堂av在线播放| 2022成人影院| 蜜桃传媒视频第一区入口在线看| 99精品免费| 欧美做受喷浆在线观看| 精品欧美aⅴ在线网站| 免费国产黄色片| 国模吧一区二区三区| jizz性欧美23| 人体内射精一区二区三区 | 亚洲女优在线观看| 色视频成人在线观看免| 艳母动漫在线看| 欧洲精品久久久| 亚洲精华一区二区三区| av免费中文字幕| 国产亚洲人成网站| 中文字幕 日韩有码| 色yeye香蕉凹凸一区二区av| 国产成人77亚洲精品www| 亚洲国产精品毛片| 久久精品国产在热久久| 日本黄色片免费观看| 91精品免费观看| 国产福利在线免费观看| 国产亚洲一区二区三区在线播放| 99re国产精品| 娇妻被老王脔到高潮失禁视频| 欧美日韩一级二级三级| 黄色免费在线观看网站| 成人女人免费毛片| 一区二区三区四区五区精品视频 | 性猛交ⅹ×××乱大交| 最新日韩av在线| 亚洲精品久久久久avwww潮水| 久久久久久综合网天天| 婷婷精品在线| 欧美成年人视频在线观看| 亚洲免费观看高清完整版在线 | 欧美巨大黑人极品精男| swag国产精品一区二区| 国产欧美高清在线| 国产精品不卡视频| 成人毛片在线免费观看| 欧美一级成年大片在线观看 | www.激情网| 久久综合色播五月| 国产有码在线观看| 午夜精品理论片| 日产精品一区二区| 国产乱淫av片| 欧美日韩色一区| 黄色软件视频在线观看| 天天人人精品| 高清av一区二区| 中文字幕免费播放| 久久久久久久久久婷婷| 欧美伦理影院| 成人做爰www看视频软件| 在线视频综合导航| 青青青国内视频在线观看软件| 欧美日本韩国国产| 国产成人精品免费视频网站| 亚洲综合久久网| 欧美激情精品久久久久久久变态| 九九在线高清精品视频| 中文字幕久久久久久久| 欧美午夜一区二区三区|