蹣跚前行者
擴展閱讀
內(nèi)存的三種分配方式:
1. 從靜態(tài)存儲區(qū)分配:此時的內(nèi)存在程序編譯的時候已經(jīng)分配好,并且在程序的整個運行期間都存在。全局變量,static變量等在此存儲。
2. 在棧區(qū)分配:相關(guān)代碼執(zhí)行時創(chuàng)建,執(zhí)行結(jié)束時被自動釋放。局部變量在此存儲。棧內(nèi)存分配運算內(nèi)置于處理器的指令集中,效率高,但容量有限。
3. 在堆區(qū)分配:動態(tài)分配內(nèi)存。用new/malloc時開辟,delete/free時釋放。生存期由用戶指定,靈活。但有內(nèi)存泄露等問題。
常見內(nèi)存錯誤及對策
1. 內(nèi)存分配未成功,卻被使用。
對策:使用內(nèi)存之前檢查是否分配成功。用p!=NULL判斷。
2. 內(nèi)存分配成功,未初始化就被使用。
內(nèi)存的缺省值沒有統(tǒng)一的標準。大部分編譯器以0作為初始值,但不完全是。
對策:內(nèi)存初始化時賦初值。
3. 內(nèi)存操作越界。
對策:只能是小心了。
4. 釋放了內(nèi)存,仍然使用。
(1) 使用顯示delete和free的野指針。
對策:釋放完內(nèi)存,將指針置為NULL。
(2) 使用隱式delete和free的野指針。主要是指函數(shù)返回指向棧內(nèi)存的指針或引用。
對策:當然是不要返回就可以了。
5. 未釋放內(nèi)存,導(dǎo)致內(nèi)存泄露。
用new/malloc開辟了內(nèi)存,沒用delete/free釋放.
對策:new和delete的個數(shù)一定相同;malloc和free的個數(shù)一定相同;new[]和[]delete一定對應(yīng)。示例1:返回指向棧空間的指針
輸出結(jié)果:亂碼
Hello World!
Hello World!示例2:new和delete雖然對應(yīng),但delete釋放不成功
運行時錯誤。P雖然是動態(tài)開辟的內(nèi)存,但在第二條語句后p已經(jīng)指向了靜態(tài)存儲區(qū)上的地址,而對指向靜態(tài)存儲區(qū)的指針是不能用delete釋放的。此時不僅運行時錯誤,還有內(nèi)存泄露。
posted on 2010-06-05 09:34 幸運草 閱讀(869) 評論(3) 編輯 收藏 引用 所屬分類: C++
str = NULL; 這句應(yīng)該是正確的吧 回復(fù) 更多評論
str = NULL;第29行,把指針綁定到安全區(qū) 回復(fù) 更多評論
@tool119應(yīng)該是正確的,謝謝指正,不知道當時怎么想的,忘了 回復(fù) 更多評論
Powered by: C++博客 Copyright © 幸運草