国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

.NET垃圾收集關鍵方法解析

開發 后端
文章通過分析.NET垃圾收集中的重要方法,讓大家更加了解.Net GC的運行機制,相信大家通過本文,能夠很全面的了解.NET GC方面的知識。

之前51cto曾報道過關于.NET垃圾收集機制中的算法與代齡,說到.NET垃圾收集,就不得不提到其中的關鍵方法,其是實現.NET GC運行機制的前提。

1.Dispose()方法

Dispose可用于釋放所有資源,包括托管的和非托管的,需要自己實現。大多數的非托管資源都要求手動釋放,我們應當為釋放非托管資源公開一個方法,實現釋放非托管資源的方法有很多種,實現IDispose接口的Dispose方法是***的,這可以給使用你類庫的程序員以明確的說明,讓他們知道怎樣釋放你的資源;而且C#中用到的using語句快,也是在離開語句塊時自動調用Dispose方法。

這里需要注意的是,如果基類實現了IDispose接口,那么它的派生類也必須實現自己的IDispose,并在其Dispose方法中調用基類中Dispose方法。只有這樣的才能保證當你使用派生類實例后,釋放資源時,連同基類中的非托管資源一起釋放掉。

使用using與try+finally的區別

可以說二者沒有任何區別,因為using只是編輯器級的優化,它與try+finally有著相同的作用,以下是一段使用using的代碼,它在IL階段也是以try+finally呈現的,但是,using的優點是,在代碼離開using塊時,using會自動調用Idispose接口的Dispose()方法。

  1. public partial class _Default : System.Web.UI.Page  
  2. {      
  3. protected void Page_Load(object sender, EventArgs e)   
  4. {   
  5. using (DataSet ds = new DataSet())  
  6. {   
  7.  }  
  8. }  
  1. .method family hidebysig instance void  Page_Load(object sender,class [mscorlib]System.EventArgs e) cil managed  
  2. {  
  3.     // 代碼大小       29 (0x1d)  
  4.     .maxstack  2  
  5.     .locals init ([0] class [System.Data]System.Data.DataSet ds,  
  6.              [1] bool CS$4$0000)  
  7.     IL_0000:  nop  
  8.     IL_0001:  newobj     instance void [System.Data]System.Data.DataSet::.ctor()  
  9.     IL_0006:  stloc.0  
  10.     .try  
  11.     {  
  12.       IL_0007:  nop  
  13.       IL_0008:  nop  
  14.       IL_0009:  leave.s    IL_001b  
  15.     }  // end .try  
  16.     finally  
  17.     {  
  18.       IL_000b:  ldloc.0  
  19.       IL_000c:  ldnull  
  20.       IL_000d:  ceq  
  21.       IL_000f:  stloc.1  
  22.       IL_0010:  ldloc.1  
  23.       IL_0011:  brtrue.s   IL_001a  
  24.       IL_0013:  ldloc.0  
  25.       IL_0014:  callvirt   instance void [mscorlib]System.IDisposable::Dispose()  
  26.       IL_0019:  nop  
  27.       IL_001a:  endfinally  
  28.     }  // end handler  
  29.     IL_001b:  nop  
  30.     IL_001c:  ret  
  31. } // end of method _Default::Page_Load 

2. GC.Collect()方法

如果我們在程序中顯式的調用了垃圾收集器的collect接口,那么垃圾收集器會立即運行,完成內存對象的標記、壓縮與清除工作,使用GC.Collect(i)還可以指定回收的代,然而aicken并不贊成各位同學顯式調用它:

(1)GC.Collect()做的并不只是回收內存,就像***節中介紹的,在回收了內存之后,GC會重新整理內存,修正對象指針,讓空閑內存連續,供CLR順序分配內存,提高新建對象的效率。內存壓縮整理工作非常耗用計算資源。

(2)很少有人會關心到GC除了在內存吃緊以及資源空閑時運行,還會在什么時候運行。 其實GC的運行時機,還要受到一個叫做“策略引擎”的部件控制,它會觀察GC的收集頻率、效率等等。它會根據GC回收效果,調整GC運行的頻率:即當某次GC回收效果頗豐時,它便會增加GC運行的頻率,反之亦然。

所以如果剛剛發生了一次自然的收集,垃圾對象就會非常之少,而此時程序又顯式的進行了收集調用,那么自然, GC雖然小有收獲,但是策略引擎就會認為:這很不值得,才收集了這么點垃圾,也許該減少GC的次數。這樣一來,垃圾收集器努力保持的自然節奏就被打亂了,同時,對象類型的創建效率與頻率,也會被“策略引擎”捕捉到,從而改變代的數量與容量。

所以,額外的調用GC,代價高昂,甚至會降低效率。顯示的調用GC.Collect(),實質是在用“時間換空間”,而通常在程序設計中,我們推薦的設計原則是“空間換時間”,比如使用各種各樣的緩存,也有例外,如果你掌握了整個應用程序的情況,明確的知道何時會產生大量垃圾,也是可以顯示調用該方法的。綜上,盡量不要顯示調用GC.Collect(),因為服務器的CPU比內存要貴的多! #p#

3. 析構函數(Finalize())

我們知道,GC只負責釋放托管資源,非托管資源GC是無法釋放的。類似文件操作、數據庫連接等都會產用非托管資源。Finalize方法是用于釋放非托管資源的,等同于C#中是析構函數,C#編譯器在編譯構造函數時,會隱式的將析構函數編譯為Finalize()對應的代碼,并確定在finally塊中執行了base.Finalize()。析構函數中只能釋放非托管資源,而不要在任何托管資源進行析構,原因如下:

(1)你無法預測析構函數的運行時機,它不是按順序執行的。當析構函數被執行的時候,也許你進行操作的托管資源已經被釋放了。

(2)包含Finalize()的對象,需要GC的兩次處理才能刪除。

(3)CLR會在單獨的線程上執行所有對象的Finalize()方法,無疑,如果頻繁的Finalize(),會降低系統的性能。

下面我們來重點說說第(2)點,為何包含Finalize()的對象,需要兩次GC才能被清除。首先要了解與Finalize相關的兩個隊列:終止隊列(Finalization Queue)與可達隊列(Freachable Queue),這兩個隊列存儲了一組指向對象的指針,當程序中在托管堆上分配空間時(new),如果該類含有析構函數,GC將在Finalization Queue中添加一個指向該對象的指針。

在GC***運行時,會在已經被確認為垃圾的對象中遍歷,如果某個垃圾對象的指針被Finalization Queue包含,GC將這個對象從垃圾中分離出來,將它的指針儲存到Freachable Queue中,并在Finalization Queue刪除這個對象的指針記錄,這時該對象就不是垃圾了——這個過程被稱為是對象的復生(Resurrection)。當Freachable Queue一旦被添加了指針之后,它就會去執行對象的Finalize()方法,清除對象占用的資源。

當GC再次運行時,便會再次發現這個含有Finalize()方法的垃圾對象,但此時它在Finalization Queue中已經沒有記錄了(GC***運行時刪掉了它的Finalization Queue記錄),那么這個對象就會被回收了,至此,通過GC兩次運行,終于回收了帶有析構函數的對象。復活實例:

  1. private void Form1_Load(object sender, EventArgs e)   
  2. {  
  3. Resource re = new Resource();     
  4. re = null;GC.Collect();  
  5. GC.WaitForPendingFinalizers();  
  6. //***GC.Collect()沒起作用哦。   
  7. label1.Text = re.num.ToString();  
  8. }    
  9. public class Resource  
  10. {  
  11. public int num;  
  12. ~Resource()  
  13. {  
  14.  
  15. }  
  16. }  

看了上面的代碼,大家應該了解什么是復活了吧!那么為什么要復生呢?因為***GC時,這個對象的Finalize()方法還沒有被執行,如果不經過復生就被GC掉,那么就連它的Finalize()一起回收了,Finalize()就無法運行了,所以必須先復生,以執行它的Finalize(),然后再回收。

還有兩個方法ReRegisterForFinalize和SuppressFinalize需要講一講,ReRegisterForFinalize是將指向對象的指針重新添加到Finalization Queue中(即召喚系統執行Finalize()方法),SuppressFinalize是將對象的指針從Finalization Queue中移除(即拒絕系統執行Finalize()方法)。

SuppressFinalize用于那些即有析構函數來釋放資源,又實現了Dispose()方法釋放資源的情況下:將GC.SuppressFinalize(this)添加至Dispose()方法中,以確保程序員調用Dispose()后,GC就不必再次收集了,即實現Idisposable中的Dispose()方法,又使用析構函數,一個雙保險,大家不要迷惑,其實在釋放非托管資源時,使用一個即可,推薦使用前者。代碼如下:

  1. public class Resource : Idisposable  
  2. {  
  3.   private bool isDispose = false;  
  4.   //實現Dispose(),后面還有析構函數,以防程序員忘記調用Dispose()方法  
  5.     public void Dispose()   
  6.       {  
  7.        Dispose(true);  
  8.     GC.SuppressFinalize(this);  
  9.       }  
  10.    protected virtual void Dispose(bool disposing)  
  11.    {  
  12.     if (!isDispose)  
  13.     {  
  14.      if (disposing)  
  15.      {  
  16.       //清理托管資源  
  17.      }  
  18.      //清理非管資源  
  19.     }  
  20.     isDispose = true;  
  21.    }  
  22.       Resource ()  
  23.    {  
  24.     Dispose(false);  
  25.    }  
  26.  } 

4.弱引用(WeakReference)

***一個話題:弱引用。在編程中,對于那些大對象建議使用這種引用方式,這種引用不影響GC回收:我們用過了某個對象,然后將其至null,這樣GC就可以快速回收它了,但是沒過多久我們又需要這個對象了,沒辦法,只好重新創建實例,這樣就浪費了創建實例所需的計算資源;而如果不至null,就會浪費內存資源。對于這種情況,我們可以創建一個這個大對象的弱引用,這樣在內存不夠時GC可以快速回收,而在沒有被GC回收前我們還可以再次利用該對象。

  1. public class SomeObject   
  2. {  
  3.  
  4. }  
  5. public static void Main()   
  6. {  
  7.  SomeObject so = new SomeObject();  
  8.  WeakReference WRso = new WeakReference(so);  
  9.  so = null;  
  10.  Console.WriteLine(WRso.IsAlive); // True  
  11.  // 調用GC 手動回收。  
  12.  GC.Collect();  
  13.  Console.WriteLine(WRso.IsAlive); // False  

看到沒,在so = null;后,它的弱引用依然是可用的。所以對于大對象的使用,aicken建議使用此種方式。另外,弱引用有長短之分:長弱引用在對象終結后,依然追蹤對象;短弱引用則反之,aicken不建議人為干預GC的工作成果,所以推薦使用短弱引用,即上面代碼中的方式。

文章原標題:.NET Discovery系列之三--深入理解.NET垃圾收集機制(下)

原文鏈接:http://www.cnblogs.com/isline/archive/2009/03/04/1402713.html

【編輯推薦】

  1. .NET垃圾收集機制 了解算法與代齡
  2. 淺析提高.NET垃圾回收性能的幾種方法
  3. 觀點:微軟.NET各子技術領域的應用前景
  4. .NET Framework 4.0功能特點詳細講解
  5. 深入.NET Framework 4.0 關于Lazy的點滴
責任編輯:王曉東 來源: CSDN博客
相關推薦

2010-01-06 16:33:50

.Net Framew

2010-02-22 08:58:35

JVM內存模型垃圾收集

2009-10-30 10:47:48

VB.NET垃圾收集器

2010-03-04 10:08:54

.Net垃圾收集

2009-06-15 16:14:40

Java垃圾收集算法GC

2024-03-27 10:27:35

延遲垃圾收集器

2024-01-15 11:12:28

Go內存開發

2024-07-15 08:00:00

2009-09-18 09:16:06

.NET垃圾回收

2021-09-07 11:23:09

智能垃圾箱物聯網IOT

2010-01-21 16:37:56

VB.NET變量聲明

2011-08-17 15:37:23

Objective-C垃圾收集

2011-05-10 16:04:45

Java垃圾收集器

2010-01-18 18:06:07

VB.NET多線程

2010-01-21 17:48:25

VB.NET Sing

2010-01-15 16:12:40

VB.NET調用DLL

2024-05-28 00:00:03

Java垃圾收集機制

2011-07-21 14:54:26

java垃圾收集器

2023-02-26 11:50:04

Hbase程序Oracle

2017-05-09 15:34:54

方案垃圾收集信息化
點贊
收藏

51CTO技術棧公眾號

欧美日韩国产在线观看| 久久视频在线免费观看| 亚洲xxxx2d动漫1| 国产高清久久久久| 日韩精品电影网站| 久久精品青草| 国产精品美女www| 2021年精品国产福利在线| 亚洲天堂av女优| av老司机在线观看| 日韩免费一区二区三区在线播放| 日韩a级作爱片一二三区免费观看| 亚洲精品成人在线| 色琪琪免费视频网站| 成人免费在线视频| a√免费观看在线网址www| 国产嫩草影院久久久久| 久久亚洲中文字幕无码| av电影天堂一区二区在线观看| www.18av.com| 国产精品白丝jk白祙喷水网站| 中文字幕久精品免| 韩国av一区二区三区四区| 中文精品一区二区三区| 国模一区二区三区白浆| 波多野结衣与黑人| 99精品桃花视频在线观看| 97中文字幕在线| 不卡在线观看av| 男人天堂网视频| 中文欧美字幕免费| 黄色网址三级| 一二三四区精品视频| 在线免费91| 欧美色图天堂网| 亚洲国产精品精华素| 精品国产乱码久久久久久浪潮 | 黄污在线观看| 欧美色网站导航| 欧洲精品二区| 中文字幕亚洲综合久久| 成人资源在线| 99精品99久久久久久宅男| 可以看av的网站久久看| 欧美精品一区二区三区三州| 久久久天堂av| 色视频精品视频在线观看| 欧美老人xxxx18| 日韩精品免费观看视频| 91sa在线看| 雨宫琴音一区二区在线| 国产福利片一区二区| 国产无遮挡一区二区三区毛片日本| 三上悠亚一区| 日韩一二三区视频| 136福利精品导航| 成人看片在线| 狠狠色2019综合网| 久久综合色播| 欧美成人艳星乳罩| 亚洲国产高清在线观看| 懂色av一区二区三区在线播放| 捆绑调教美女网站视频一区| 国产免费网址| 精品国产亚洲在线| 国产精品丝袜在线播放| 免费试看一区| 亚洲色图在线视频| 18aaaa精品欧美大片h| 26uuu久久噜噜噜噜| 天堂影院一区二区| 女人高潮特级毛片| 亚洲成人av在线| 女厕嘘嘘一区二区在线播放 | 青草国产精品久久久久久| 特级丰满少妇一级| 日韩欧美一区二区三区在线| 国产成人福利av| 亚洲欧洲精品在线| 天天影视色香欲综合网老头| 日韩经典一区| 久久精品magnetxturnbtih| 国产精品午夜在线观看| 川上优av中文字幕一区二区| 国产精品久久久久久一区二区| 国产一区二区福利| 自拍视频在线| 国产精品99久久久久久白浆小说| 久久国产精品露脸对白| 一个人免费视频www在线观看| 久久激情视频免费观看| 欧美亚洲视频| 四虎影视在线播放| 欧美中文字幕视频| 成人免费va视频| 精灵使的剑舞无删减版在线观看| 国产精品一香蕉国产线看观看 | 欧美性高潮床叫视频| 欧美日韩午夜电影网| 午夜午夜精品一区二区三区文| 亚洲电影第三页| 亚洲网一区二区三区| 国产精品12p| 91精品国产综合久久久久久漫画 | 国产主播欧美精品| 国产精品每日更新| 欧美日韩卡一| 伊人久久大香线蕉午夜av| 精品视频123区在线观看| 久久最新网址| 色婷婷狠狠18| 九九热这里只有精品6| 国产黄色成人av| 国产盗摄——sm在线视频| 蜜桃日韩视频| 8x8x8国产精品| 国产一区日韩一区| 欧美白人做受xxxx视频| 国产精品美女午夜av| 亚洲美女一区二区三区| 美女av一区| 色爱综合网站| 91精品国产色综合久久不卡98口 | 欧美图片激情小说| 亚洲天堂av在线免费| 国产自产2019最新不卡| 欧美理论电影| 亚洲国产成人不卡| 亚洲国产日韩欧美综合久久| 日本aⅴ精品一区二区三区 | 色菇凉天天综合网| 999国产精品999久久久久久| 国产精品久久久久久精| 午夜精品蜜臀一区二区三区免费| 91偷拍与自偷拍精品| 亚洲三级电影| 无人在线观看的免费高清视频| 久久激情视频免费观看| 久久综合久久综合久久综合| 国产精品一区免费在线| www.日本xxxx| 国产精品黄色影片导航在线观看| 一区二区三区成人| 91精品啪在线观看国产18| 国产在线视频你懂得| 久久国产精品一区二区三区四区 | 成人免费黄色网页| 黄色小网站91| 欧美精品一区二| 国产suv精品一区二区883| 成人激情视屏| 99色在线播放| 91视频国产一区| 日韩视频一区二区在线观看| 麻豆精品蜜桃视频网站| 九七影院97影院理论片免费| 成人欧美在线视频| 亚洲欧美在线视频观看| 欧美电影《轻佻寡妇》| av日韩中文| 久久av免费一区| 日韩在线视频网| 亚洲欧美日韩国产中文| 久久一区精品| 看黄在线观看| 欧美三级理论片| 国产欧美日韩免费| 日韩午夜在线影院| 久久亚洲捆绑美女| 一区二区日韩欧美| 九色porny视频在线观看| 国产1区2区在线| 国产精品主播视频| 欧美videossexotv100| 东方欧美亚洲色图在线| 另类ts人妖一区二区三区| 国产资源在线观看| www插插插无码免费视频网站| 1769国内精品视频在线播放| 欧美视频一区二| 成人免费电影视频| 香港欧美日韩三级黄色一级电影网站| 欧美大片黄色| 五月婷婷六月合| 精品亚洲欧美日韩| 久久中文字幕一区| 欧美日韩在线播| 久久精品视频免费观看| 日韩午夜一区| 日韩亚洲精品在线观看| 免费a级在线播放| 成人免费视频77777| 午夜精品福利一区二区| 日本国产欧美一区二区三区| 精品毛片免费观看| 国产黄在线观看免费观看不卡| www.激情网| 99国精产品一二二线| 久久亚洲一区二区三区四区五区高| 欧美在线一区二区|