亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網(wǎng)管 > 服務器 > 正文

.Net 垃圾回收和大對象處理 內存碎片整理

2020-05-27 13:47:37
字體:
來源:轉載
供稿:網(wǎng)友

CLR垃圾回收器根據(jù)所占空間大小劃分對象。大對象和小對象的處理方式有很大區(qū)別。比如內存碎片整理 —— 在內存中移動大對象的成本是昂貴的,讓我們研究一下垃圾回收器是如何處理大對象的,大對象對程序性能有哪些潛在的影響。

大對象堆和垃圾回收

在.Net 1.0和2.0中,如果一個對象的大小超過85000byte,就認為這是一個大對象。這個數(shù)字是根據(jù)性能優(yōu)化的經(jīng)驗得到的。當一個對象申請內存大小達到這個閥值,它就會被分配到大對象堆上。這意味著什么呢?要理解這個,我們需要理解.Net垃圾回收機制。

如大多人所知道的,.Net GC是按照“代”來回收的。程序中的對象共有3代,0代、1代和2代,0代是最年輕的對象,2代對象存活的時間最長。GC按代回收垃圾也是出于性能考慮 的;通常的對象都會在0代是被回收。例如,在一個asp.net程序中,和每一個請求相關的對象都應該在請求結束時回收掉。而沒有被回收的對象會成為1代 對象;也就是說1代對象是常駐內存對象和馬上消亡對象之間的一個緩沖區(qū)。

從代的角度看,大對象屬于2代對象,因為只有在2代回收時才會處理大對象。當某代垃圾回收執(zhí)行時,會同時執(zhí)行更年輕代的垃圾回收。比如:當1代垃圾回收時會同時回收1代和0代的對象,當2代垃圾回收時會執(zhí)行1代和0代的回收.

代是垃圾回收器區(qū)分內存區(qū)域的邏輯視圖。從物理存儲角度看,對象分配在不同的托管堆上。一個托管堆(managed heap)是垃圾回收器從操作系統(tǒng)申請的內存區(qū)(通過調用windows api VirtualAlloc)。當CLR載入內存之后,會初始化兩個托管堆,一個大對象堆(LOH –large object heap)和一個小對象對(SOH – small object heap)。

內存分配請求就是將托管對象放到對應的托管堆上。如果對象的大小小于85000byte,它會被放置在SOH;否則會被放在LOH上。

對于SOH,對象在執(zhí)行一次垃圾回收之后,會進入到下一代。也就是說如果在第一次執(zhí)行垃圾回收時,存活下來的對象會進入第二代,如果在第2次垃圾回收之后該對象仍然沒有被當作垃圾回收掉,它就會成為2代對象;2代對象就是最老的對象不會在提升代數(shù)。

當觸發(fā)垃圾回收時,垃圾回收器會在小對象堆做碎片整理,將存活下來的對象移動到一起。而對于大對象堆,由于移動內存的開銷很大,CLR團隊選擇只是清除它們,將回收掉的對象組成一個列表,以便滿足下次有大對象申請使用內存,相鄰的垃圾對象會被合并成一塊空閑的內存塊。

需要時時留意的是,直到.Net 4.0中也不會對大對象堆做碎片整理操作,將來也許會做。因此如果你要分配大對象并不想他們被移動,你可以使用fixed語句。

如下小對象堆SOH的回收示意圖

 .Net 垃圾回收和大對象處理 內存碎片整理 武林網(wǎng)

上圖中第一次垃圾回收之前有四個對象obj0-3;在第一垃圾回收之后obj1和obj3被回收了,同時obj2和obj0移動到一起了;在第二次 垃圾回收之前有分配了三個對象obj4-6;在第二次執(zhí)行垃圾回收之后obj2和obj5被回收了,obj4和obj6被移動到obj0旁邊。

下圖是大對象堆LOH回收示意圖

.Net 垃圾回收和大對象處理

可以看到在未執(zhí)行垃圾回收之前,一共有四個對象obj0-3;第一次二代垃圾回收之后obj1和obj2被回收掉了,回收掉之后obj1和obj2 所占空間被合并到了一起,在obj4申請分配內存時就把obj1和obj2回收后釋放的空間分配給它了;同時留下了一塊內存碎片。如果這個碎片的大小小于 85000byte,那么這個碎片就在這個程序的生命周期中永遠不能被再次利用了。

如果大對象堆上沒有足夠的空閑內存容納要申請的大對象空間,CLR首先會嘗試向操作系統(tǒng)申請內存,如果申請失敗,就會觸發(fā)一次二代回收來嘗試釋放一些內存。

在2代垃圾回收時,可以將不需要的內存通過VirtualFree交還給操作系統(tǒng)。交還的過程參見下圖:

.Net 垃圾回收和大對象處理

什么時候回收大對象呢?

在討論什么時候回收大對象之前先來看下普通的垃圾回收操作什么時機執(zhí)行吧。垃圾回收在下列情況下發(fā)生:

1. 申請的空間超過0代內存大小或者大對象堆的閥值,多數(shù)的托管堆垃圾回收在這種情況下發(fā)生

2. 在程序代碼中調用GC.Collect方法時;如果在調用GC.Collect方法是傳入GC.MaxGeneration參數(shù)時,會執(zhí)行所有代對象的垃圾回收,包括大對象堆的垃圾回收

3. 操作系統(tǒng)內存不足時,當應用程序收到操作系統(tǒng)發(fā)出的高內存通知時

4. 如果垃圾回收算法認為做二代回收是有收效時會觸發(fā)二代垃圾回收

5. 每一代對象堆的都有一個所占空間大小閥值的屬性,當你分配對象到某一代,你增長了內存總量接近了該代的閥值,或者分配對象導致這一代的堆大小超過了堆閥 值,就會發(fā)生一次垃圾回收。因此當你分配小對象或者大對象時,會對應消耗0代堆或者大對象堆的閥值。當垃圾回收器將對象代數(shù)提升到1代或者2代時,會消耗 1、2代的閥值。在程序運行中這些閥值是動態(tài)變化的。

大對象堆性能影響

讓我們先看下分配大對象的代價。 CLR為每個新對象分配內存時都要保證這些內存清空的,是沒有被其他對象使用的(I give out is cleared)。這就意味著分配的代價完全被清理(clearing)的代價控制著(除非在分配時觸發(fā)了一次垃圾回收)。如果清空1byte需要2個周 期(cycles),就意味著清除一個最小的大對象需要170,000個周期。通常情況下人們不會分配超大的對象,比如說在2GHz的機器上分配16M大 小的對象,大約需要16ms來清空內存。這代價太大了。

讓我們在看下回收的代價。前面提到過,大對象和2代齡對象一起回收。如果大對象或者2代對象占用空間超過其閥值時,就會觸發(fā)2代對象的回收。如果2 代回收因為大對象堆超過閥值被觸發(fā),2代對象堆本身沒有多少對象可以做回收。如果在2代堆上沒有多少對象,這問題不大。但是如果2代堆很大對象很多,過多 的2代回收就會導致性能問題。如果是臨時性的分配大對象,就需要很多的時間來運行垃圾回收;也就是說如果你持續(xù)的使用大對象然后又釋放大對象對性能會有很 大的負面影響。

大對象堆上的巨大對象通常是數(shù)組(很少有一個對象很大的情況)。如果對象中的元素是強引用,代價會很高;如果元素之間沒有相互引用,垃圾回收時就不需要遍歷整個數(shù)組。例如:用一個數(shù)組來保存二叉樹的節(jié)點,一種方法是在節(jié)點中強引用左右節(jié)點:

class Node

{

Data d;

Node left;

Node right;

}

Node[] binaryTree = new Node[num_nodes];

如果num_nodes是一個很大的數(shù)字,就意味著每個節(jié)點都至少需要查看二個引用元素。一種替代方案是在節(jié)點中保存左右節(jié)點元素的數(shù)組索引號

class Node

{

Data d;

uint left_index;

uint right_index;

}

這樣的話,元素之間的引用關系去掉了;可以通過binaryTree[left_index]來獲得引用的節(jié)點。垃圾回收器在做垃圾回收時也不需要看相關的引用元素了。

為大對象堆收集性能數(shù)據(jù)

有幾種方法可以收集大對象堆相關的性能數(shù)據(jù)。在我解釋這些方法之前,讓我們先談一下為什么需要收集大對象堆相關的性能數(shù)據(jù)。

在你開始上搜集某個方面的性能數(shù)據(jù)時,有可能你已經(jīng)找到這方面造成性能瓶頸的證據(jù);或者你已經(jīng)沒有找遍了所有方面都沒有發(fā)現(xiàn)問題。

在查找性能問題時.Net CLR Memory 性能計數(shù)器通常是應該先考慮使用的工具。和LOH相關的計數(shù)器有generation 2 collectioins(2代堆收集次數(shù))和large object heap size大對象堆大小。Generation 2 collections顯示的是進程啟動之后2代垃圾回收操作發(fā)生的次數(shù)。Large object heap size計數(shù)器顯示的是當前大對象堆的大小值,包括空閑空間;這個計數(shù)器是在每次垃圾回收操作之后做更新,并非每次分配內存都做更新。

可以參考下圖在windows性能計數(shù)器中觀察.Net CLR Memory相關性能數(shù)據(jù)

.Net 垃圾回收和大對象處理

你也可以通過程序查詢這些計數(shù)器的值;很多人通過程序的方式收集性能計數(shù)器來幫助查找性能瓶頸。

當然也可以使用調試器winddbg觀察大對象堆。

最后提示一下:到目前為止,大對象堆作為垃圾回收的一部分是不做內存碎片整理的,但是這個只是一個clr的實現(xiàn)細節(jié),程序代碼不應該依賴這個特點。如果要確保對象不會被垃圾回收器移動,就要使用fixed語句。

文章來源:伯樂在線

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
玩弄中年熟妇正在播放| 色哦色哦哦色天天综合| 午夜精品无码一区二区三区| 中文字幕一区二区人妻痴汉电车| 免费黄色在线视频| 直接在线观看的三级网址| 欧美黑人极品猛少妇色xxxxx| 日本黄色免费网址| 四虎国产精品免费观看| 国产一区二区三区免费观看在线| 黄色a级三级三级三级| 亚洲一区二区三区免费| jizzjizz中国精品麻豆| 日韩欧美国产1| 国产精品一区三区在线观看| 日韩精品一区二区三区三区免费| 欧美韩国日本一区| 在线视频不卡国产| 91theporn国产在线观看| 日韩一区二区三区四区视频| 天天伊人狠狠| xxx免费观看| 国产一区二区三区黄| 网红女主播少妇精品视频| 91极品视频在线| 国产真实老熟女无套内射| 99久久久国产精品免费蜜臀| 欧美另类极品videosbest视频| 日韩高清一区在线| 亚洲人在线观看视频| 97香蕉久久| 嫩草嫩草嫩草嫩草| 2014亚洲精品| 亚洲综合欧美| 69亚洲精品久久久蜜桃小说| 国产精品久久网站| 免费一级特黄录像| 18被视频免费观看视频| 亚洲精品伦理在线| 久久精品视频网站| 欧美日韩电影在线观看| av网站免费线看精品| 99免费观看视频| 99这里只有精品视频| 欧州一区二区三区| 欧美诱惑福利视频| www黄在线观看| 欧美视频在线免费播放| 亚洲三级电影在线观看| 一本一本久久a久久精品综合妖精| 欧美高清免费| 欧美日韩成人一区二区| 日韩在线观看免| 爱爱爱爱免费视频| 91麻豆精品国产91久久| 欧美日本二区| 成人ssswww在线播放| 一道本在线观看| 亚洲特级片在线| 国产精品小仙女| 久草在线免费福利| 一区二区三区中文| 精品一二三四区| 亚洲欧洲日产国码二区| 中文资源在线播放| 国产视频在线观看一区二区三区| 久久久久久综合网天天| 国产精选久久久久久| 亚洲精品一区中文| 天堂在线亚洲| 久久精品在线视频| 99免费看香蕉视频| 国产精品久久久久久久第一福利| 综合一区av| 极品校花啪啪激情久久| 丰满岳乱妇一区二区三区| 在线观看久久久久久| 一级特黄特色的免费大片| ririsao久久精品一区| 亚洲午夜国产成人av电影男同| 亚洲欧美日本免费| 国产精品视频精品视频| 91小视频在线观看| 亚欧洲精品视频| 午夜伦理一区二区| 三年中文在线观看免费大全中国| 日韩三级在线免费观看| 午夜精品一区二区三区电影天堂| 天堂а√在线中文在线新版| 亚洲视频在线观看免费| 中文字幕av无码一区二区三区| 少妇高清精品毛片在线视频| 亚洲伦理在线精品| 日本成人激情视频| 一区二区三区视频免费在线观看| 影音先锋人妻啪啪av资源网站| 国产日产一区| 天天综合亚洲| www.偷拍.com| 亚洲精品一区中文字幕乱码| 亚洲第一成年免费网站| 亚洲丝袜一区| 人人干人人看| 亚洲二区视频在线| 九一亚洲精品| 国产精品无码一区二区桃花视频| 国产欧美日韩最新| 亚洲国产精品va在线| av在线免费观看网| 国产在线不卡av| 国产一级18片视频| 性欧美xxxx视频在线观看| 国产欧美日韩综合精品一区二区| 亚洲精品欧美精品| 黄色污网站在线免费观看| 欧美国产激情一区二区三区蜜月| 国产不卡av一区二区| 国产一区再线| 国内精品伊人久久久久影院对白| 毛片.com| 日本黄色免费网址| 4444亚洲人成无码网在线观看| 毛片基地黄久久久久久天堂| 日韩中文娱乐网| 91产国在线观看动作片喷水| 美国av免费观看| 亚洲欧美日韩在线| 成人在线免费看| 秋霞av亚洲一区二区三| 亚洲视频www| www.亚洲激情.com| 免费黄网大全| 亚洲欧洲精品一区| 性色av蜜臀av浪潮av老女人| 精品国产免费人成电影在线观...| 亚洲av无码一区二区三区在线| 视频一区视频二区中文字幕| 日本一区二区三区在线不卡| 日本中文字幕在线观看| 欧美巨大丰满猛性社交| 国产真人真事毛片| 北条麻妃在线视频观看| 永久免费看黄网站| 成年人免费在线视频网站| 亚洲成年人网站在线观看| 国产精品99久久久久久似苏梦涵| gogogo影视剧免费观看在线观看| 精品人妻aV中文字幕乱码色欲| 欧美激情亚洲国产| 78精品国产综合久久香蕉| а中文在线天堂| 成人黄色在线网站| 先锋影音av在线| av网址观看| 欧美1区2区| 天堂中文8资源在线8| 亚洲 高清 成人 动漫| 国产精品第一页在线观看| 国产激情在线观看视频| 久久99久久98精品免观看软件| 亚洲成人777| 日本妇女毛茸茸| 中文亚洲欧美| 老太脱裤让老头玩ⅹxxxx| 婷婷激情四射网| 香蕉视频成人在线| 欧美国产欧美亚州国产日韩mv天天看完整| 91免费版黄色| 最近2019中文字幕在线高清| 91在线精品视频| 欧美成人精品在线| 亚洲美女在线视频| 日韩一级片免费看| 黄色在线小视频| 欧美剧情片在线观看| 成人免费视频视频| 日韩精品最新在线观看| 久久久噜噜噜www成人网| 国产精品欧美在线| 99久久久免费精品国产一区二区| 91成人精品一区二区| 久久精品国产成人一区二区三区| 国产精品videossex| h网站免费观看| 精品欧美一区免费观看α√| 久久精品a一级国产免视看成人| 亚洲天堂av片| 伊人色在线观看| 国产性天天综合网| 青青草成人免费视频| 亚洲观看黄色网| 综合图区亚洲白拍在线| 91.com在线| 91久久久亚洲精品| 国产无人区一区二区三区| 麻豆精品视频在线观看视频| 日韩精品无码一区二区三区久久久| 国产福利资源在线| 亚洲午夜激情视频| 亚洲a视频在线| 青青草国产在线观看| 91黄色免费看| 日韩在线观看| 91在线视频18| 可以免费看av的网址| 美国欧美日韩国产在线播放| 无码熟妇人妻av在线电影| 韩国av在线播放| 中文字幕av一区| 免费在线国产| 成人片在线播放| 波多野结衣欲乱| 日本亚洲天堂网| 青青草在线免费视频| 色综合色综合网色综合| 可以免费看不卡的av网站| 伊人网在线观看| 中文字幕日韩精品在线| 免费在线观看污污视频| 国产精品欧美一级免费| 成人免费高清在线播放| 中文字幕 在线观看| 偷拍女澡堂一区二区三区| 国产麻豆视频在线观看| 污视频在线免费观看一区二区三区| 激情小视频在线观看| 久久精品久久久久电影| 18欧美亚洲精品| 在线免费观看麻豆| 欧美男插女视频| 91精品国产91久久久久福利| 免费无码毛片一区二三区| 男的操女的网站| 欧美激情亚洲色图| 亚洲欧美综合精品久久成人| 亚洲天堂av资源在线观看| 99久久精品免费精品国产| 国产精品初高中害羞小美女文| 精品伦理精品一区| 国产香蕉免费精品视频| 国产精品黑丝在线播放| 精品成人av一区二区在线播放| 久久精品免视看国产成人| 日本久久精品电影| 色婷婷.com| 亚洲欧洲一级| 激情黄色小视频| www四虎com| 日本大片免费看| 精品一区二区三区在线观看| 国产精品乱人伦中文| 欧美日韩123区| 一本久道久久综合| 激情综合色播激情啊| 麻豆传媒视频在线观看免费| ㊣最新国产の精品bt伙计久久| 国产一区2区在线观看| 欧美综合影院| 91麻豆精品国产无毒不卡在线观看| 亚洲精品成人免费| 在线免费黄色毛片| 日本高清视频精品| 一区二区三区日韩视频| 欧美主播一区二区三区美女 久久精品人| 国产一区二区网站| 国产美女视频免费看| 先锋影音资源999| 成年人黄色大片在线| 在线免费看av片| 日韩欧美在线中字| 亚欧洲精品在线视频免费观看| 久久精品黄色| 免费不卡中文字幕在线| 中文字幕一区二区在线视频| 亚洲天堂成人av| 日韩精品一区二区三区av| 一区二区激情| 男女免费视频网站| www天堂在线| 丁香六月婷婷综合| 亚洲一区二区三区高清视频| 动漫3d精品一区二区三区| 国产视频精品va久久久久久| 日韩毛片视频在线看| 国产综合香蕉五月婷在线| 日韩精品久久理论片| 欧美精品亚洲| 久久天天躁狠狠躁夜夜av| 男人天堂网在线| 99久久伊人精品| 美女一区网站| 国产目拍亚洲精品99久久精品| 免费高清不卡av| 免费av一级片| 麻豆精品新av中文字幕| 欧美国产亚洲视频| 色悠悠在线视频| 久草热8精品视频在线观看| 日韩精品美女| 日韩午夜一区| 国产嫩草影院久久久久| 色婷婷**av毛片一区| 99在线视频免费| 成人午夜高潮视频| 天堂av免费看| 亚洲黄页网在线观看| 成 人 黄 色 片 在线播放| 91福利在线尤物| 亚洲精品裸体| 日本一区二区三区四区| 91精品一区二区三区在线观看| 久久综合久久久久| 欧美少妇一区二区| 久久久亚洲高清| 国产一区二区三区免费| 第一福利在线| 亚洲色图视频免费播放| 欧美婷婷精品激情| 高h视频在线观看| 中文字幕免费高清电视剧网站在线观看| 婷婷综合激情| 欧美成人日本| 久久日本片精品aaaaa国产| 中文字幕一区二区三区视频| 久久婷婷一区二区三区| 欧美日韩高清在线| 亚洲一区在线观看免费| 菠萝蜜视频在线观看www入口|