.net的GC機制有兩個問題:首先GC並不能釋放全部資源,它更不能釋放非託管資源。其次,GC也不是實時的,全部GC存在不肯定性。
爲了解決這個問題donet提供了析構函數程序員
public class TestClass : System.IDisposable { //供程序員顯式調用的Dispose方法 public void Dispose() { //調用帶參數的Dispose方法,釋放託管和非託管資源 Dispose(true); //手動調用了Dispose釋放資源,那麼析構函數就是沒必要要的了,這裏阻止GC調用析構函數 System.GC.SuppressFinalize(this); } //protected的Dispose方法,保證不會被外部調用。 //傳入bool值disposing以肯定是否釋放託管資源 protected void Dispose(bool disposing) { if (disposing) { ///TODO:在這裏加入清理"託管資源"的代碼,應該是xxx.Dispose(); } ///TODO:在這裏加入清理"非託管資源"的代碼 } //供GC調用的析構函數 ~TestClass() { Dispose(false);//釋放非託管資源 } }
而即便咱們忘記了在合適的時候調用Dispose,GC也會在釋放對象的時候幫咱們清理非託管資源的。GC所充當的角色只是一種保障手段,它應該充當這種角色,咱們不能過度依賴它。實際上,在較大的模塊退出時咱們還應該及時地手動調用GC.Collect進行垃圾回收。函數
爲何實現IDisposable接口的類的對象,由於.net CLR是採用GC(垃圾回收器)機制管理內存,不想C++語言那樣,能保證對象的析構函數在做用域結束時被老是被自動調用,有時若是程序運行的過程當中一直沒有知足啓動GC的條件,則可能GC一次也沒啓動。 這樣,若是一個類須要佔用重要資源,就應該實現IDisposable接口,或者使用另外一種簡捷的方式:使用Using,如:this
Using(MyClass myObj = new MyClass()) spa
{ ... } .net
對於沒有實現IDisposable接口的,也就沒什麼Dispose方法,但他們的Finalize一樣不能保證被調用。 code
Using(MyClass myObj = new MyClass()) 對象
{ ... } blog
是一種好方法,可是隻有MyClass實現了IDisposable接口才能這樣寫.接口