1. 程式人生 > >記憶體洩漏與記憶體溢位的區別?

記憶體洩漏與記憶體溢位的區別?

記憶體洩漏

記憶體洩漏(memory leak): 是指程式在申請記憶體後,無法釋放已申請的記憶體空間,一次記憶體洩露危害可以忽略,但記憶體洩露堆積後果很嚴重,無論多少記憶體,遲早會被佔光。
一般我們所說的記憶體洩漏是指堆記憶體的洩漏,堆記憶體是指程式從堆中分配的,大小任意的(記憶體塊的大小可以在程式執行期決定),使用完成之後必須顯示釋放記憶體。應用程式一般使用malloc、realoc、new等函式從堆中分配到一塊記憶體塊,使用完成後,程式必須負責相應的釋放。在C中使用free(),C++中delete、delete[]、free()。而Java中由於垃圾回收機制不用手動釋放。
如果記憶體不能釋放,這塊記憶體就不能再次使用,我們就說這塊記憶體洩漏了。

記憶體溢位

記憶體溢位(out of memory):程式要求的記憶體,超出了系統所能分配的範圍。如:我們用一個int型4位元組的資料來裝一個float型8位元組的資料,就會產生記憶體溢位。不過我們在程式設計是可以強制型別轉換int XX = (int)float;只取float 4位元組資料給int.

以發生的方式來分類,記憶體洩漏可以分為4類:
1. 常發性記憶體洩漏。發生記憶體洩漏的程式碼會被多次執行到,每次被執行的時候都會導致一塊記憶體洩漏。
2. 偶發性記憶體洩漏。發生記憶體洩漏的程式碼只有在某些特定環境或操作過程下才會發生。常發性和偶發性是相對的。對於特定的環境,偶發性的也許就變成了常發性的。所以測試環境和測試方法對檢測記憶體洩漏至關重要。
3. 一次性記憶體洩漏。發生記憶體洩漏的程式碼只會被執行一次,或者由於演算法上的缺陷,導致總會有一塊僅且一塊記憶體發生洩漏。比如,在類的建構函式中分配記憶體,在解構函式中卻沒有釋放該記憶體,所以記憶體洩漏只會發生一次。
4. 隱式記憶體洩漏。程式在執行過程中不停的分配記憶體,但是直到結束的時候才釋放記憶體。嚴格的說這裡並沒有發生記憶體洩漏,因為最終程式釋放了所有申請的記憶體。但是對於一個伺服器程式,需要執行幾天,幾周甚至幾個月,不及時釋放記憶體也可能導致最終耗盡系統的所有記憶體。所以,我們稱這類記憶體洩漏為隱式記憶體洩漏。

從使用者使用程式的角度來看,記憶體洩漏本身不會產生什麼危害,作為一般的使用者,根本感覺不到記憶體洩漏的存在。真正有危害的是記憶體洩漏的堆積,這會最終消耗盡系統所有的記憶體。從這個角度來說,一次性記憶體洩漏並沒有什麼危害,因為它不會堆積,而隱式記憶體洩漏危害性則非常大,因為較之於常發性和偶發性記憶體洩漏它更難被檢測到