1. 程式人生 > >關於內存溢出和內存泄漏

關於內存溢出和內存泄漏

strong 垃圾 決定 內存泄漏 垃圾回收機制 結束 知識庫 data sha

內存泄漏

內存泄漏(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. 隱式內存泄漏。程序在運行過程中不停的分配內存,但是直到結束的時候才釋放內存。嚴格的說這裏並沒有發生內存泄漏,因為最終程序釋放了所有申請的內存。但是對於一個服務器程序,需要運行幾天,幾周甚至幾個月,不及時釋放內存也可能導致最終耗盡系統的所有內存。所以,我們稱這類內存泄漏為隱式內存泄漏。

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

關於內存溢出和內存泄漏