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