內(nèi)存管理
內(nèi)存的三種分配方式:
1. 從靜態(tài)存儲區(qū)分配:此時的內(nèi)存在程序編譯的時候已經(jīng)分配好,并且在程序的整個運行期間都存在。全局變量,static變量等在此存儲。
2. 在棧區(qū)分配:相關代碼執(zhí)行時創(chuàng)建,執(zhí)行結束時被自動釋放。局部變量在此存儲。棧內(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)存,導致內(nèi)存泄露。
用new/malloc開辟了內(nèi)存,沒用delete/free釋放.
對策:new和delete的個數(shù)一定相同;malloc和free的個數(shù)一定相同;new[]和[]delete一定對應。
示例1:返回指向棧空間的指針

2



3

4

5

6

7

8



9

10

11

12

13

14



15

16

17

18

19

20



21

22

23

24

25

26

27

28

29

30

31

32

33

34

輸出結果:
亂碼
Hello World!
Hello World!
示例2:new和delete雖然對應,但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 幸運草 閱讀(862) 評論(3) 編輯 收藏 引用 所屬分類: C++