1.如果你釋放的是托管托管代碼的內(nèi)存,那么托管代碼的內(nèi)存管理是自動的,.NET可以保證我們的托管程序在結(jié)束時(shí)全部釋放。
市中ssl適用于網(wǎng)站、小程序/APP、API接口等需要進(jìn)行數(shù)據(jù)傳輸應(yīng)用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價(jià)格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:028-86922220(備注:SSL證書合作)期待與您的合作!
2.如果是非托管資源時(shí).NET就不能自動管理了,下面是釋放非托管資源內(nèi)存方法
當(dāng)我們利用如數(shù)據(jù)庫、文件等非托管資源時(shí),就要用到.NET Framework中的標(biāo)準(zhǔn): IDisposable接口。按照標(biāo)準(zhǔn),所有有需要手動釋放非托管資源的類都得實(shí)現(xiàn)此接口。這個(gè)接口只有一個(gè)方法,Dispose(),不過有相對的 Guidelines指示如何實(shí)現(xiàn)此接口,在這里我向大家說一說。實(shí)現(xiàn)IDisposable這個(gè)接口的類需要有這樣的結(jié)構(gòu):
[Visual Basic]
Public Class Base
Implements IDisposable
Public Overloads Sub Dispose() Implements IDisposable.Dispose
Me.Dispose(True)
GC.SuppressFinalize(Me)
End Sub
Protected Overloads Overridable Sub Dispose(ByVal disposing As Boolean)
If disposing Then
' 托管類
End If
' 非托管資源釋放
End Sub
Protected Overrides Sub Finalize()
Me.Dispose(False)
MyBase.Finalize()
End Sub
End Class
Public Class Derive
Inherits Base
Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)
If disposing Then
' 托管類
End If
' 非托管資源釋放
MyBase.Dispose(disposing)
End Sub
End Class
我們要實(shí)現(xiàn)Dispose方法,實(shí)現(xiàn)這個(gè)Dispose方法的幾個(gè)準(zhǔn)則:
它不能扔出任何錯(cuò)誤,重復(fù)的調(diào)用也不能扔出錯(cuò)誤。也就是說,如果我已經(jīng)調(diào)用了一個(gè)對象的Dispose,當(dāng)我第二次調(diào)用Dispose的時(shí)候程序不應(yīng)該出錯(cuò),簡單地說程序在第二次調(diào)用Dispose時(shí)不會做任何事。這些可以通過一個(gè)flag或多重if判斷實(shí)現(xiàn)。
一個(gè)對象的Dispose要做到釋放這個(gè)對象的所有資源。拿一個(gè)繼承類為例,繼承類中用到了非托管資源所以它實(shí)現(xiàn)了IDisposable接口,如果繼承類的基類也用到了非托管資源那么基類也得被釋放,基類的資源如何在繼承類中釋放呢?當(dāng)然是通過一個(gè)virtual/Overridable方法了,這樣我們能保證每個(gè)Dispose都被調(diào)用到。這就是為什么我們的設(shè)計(jì)有一個(gè)virtual/Overridable的Dispose方法。注意我們首先要釋放繼承類的資源然后再釋放基類的資源。
因?yàn)榉峭泄苜Y源一定要被保障正確釋放所以我們要定義一個(gè)Finalizer來避免程序員忘了調(diào)用Dispose的情況。上面的設(shè)計(jì)就采用了這種形式。如果我們手動調(diào)用Dispose方法就沒有必要再保留Finalizer了,所以在Dispose中我們用了GC.SupressFinalize 將對象從Finalizer表去掉,這樣再回收時(shí)速度會更快。
那么那個(gè)disposing和"托管類"是怎么回事呢?是這樣:在"托管類"中寫所有你想在調(diào)用Dispose時(shí)讓其處于可釋放狀態(tài)的托管代碼。還記得我們說過我們不知道托管代碼是什么時(shí)候釋放的嗎?在這里我們只是去掉成員對象的引用讓它處于可被回收狀態(tài),并不是直接釋放內(nèi)存。在"托管類"中這里我們也要寫上所有實(shí)現(xiàn)了IDisposable的成員對象,因?yàn)樗麄円灿蠨ispose,所以也需要在對象的Dispose中調(diào)用他們的 Dispose,這樣才能保證第二個(gè)準(zhǔn)則。disposing是為了區(qū)分Dispose的調(diào)用方法,如果我們手動調(diào)用那么為了第二個(gè)準(zhǔn)則"托管類"部分當(dāng)然得執(zhí)行,但如果是Finalizer調(diào)用的Dispose,這時(shí)候?qū)ο笠呀?jīng)沒有任何引用,也就是說對象的成員自然也就不存在了(無引用),也就沒有必要執(zhí)行"托管類"部分了,因?yàn)樗麄円呀?jīng)處于可被回收狀態(tài)了。好了,這就是IDisposable接口的全部了?,F(xiàn)在讓我們來回想一下,以前我們可能認(rèn)為有了 Dispose內(nèi)存就會馬上被釋放,這是錯(cuò)誤的。只有非托管內(nèi)存才會被馬上釋放,托管內(nèi)存的釋放由GC管理,我們不用管。
可以將文件等分成兩部分,分別用兩個(gè)private讀取就是2線程。
內(nèi)存解決方案:不要等程序自動GC,自己手動釋放不需要內(nèi)存。
缺陷:可能會浪費(fèi)時(shí)間。
.net 有自己的資源回收機(jī)制GC。
如果變量不再使用了,所有引用該變量的其它變量也都沒用了(dispose或者賦值為空了),那么這些沒用的變量會定時(shí)的被GC自動回收,不需要自己去管理。
如果非要自己釋放資源的話,可以使用 GC.Collect() 進(jìn)行釋放,但是并不能保證一次GC.Collect()就可以釋放掉所有沒有用的資源,可能要經(jīng)過好幾輪GC.Collect()才能釋放干凈。
所以還是建議不要手動回收了,讓系統(tǒng)根據(jù)要求自動回收吧。