Posted on 2009-08-17 13:45
Prayer 閱讀(3713)
評論(0) 編輯 收藏 引用 所屬分類:
C/C++
一般的C語言書上都是這么講的:
一個(gè)程序的全局變量,static變量等從靜態(tài)存儲區(qū)分配;
局部變量,函數(shù)形參從堆棧分配;
動態(tài)申請的空間從堆上分配。
那么加入在win32環(huán)境中,這里的堆,堆棧,靜態(tài)存儲區(qū)是否就對應(yīng)著用戶的2G地址空間的某一部分?
它們究竟各在哪個(gè)位置并且各占多大空間呢?
堆;你自己分配多大就多大,但系統(tǒng)有上限,你可以測試一下你能malloc多少
棧:程序運(yùn)行所占空間,可以完全占用完吧,Windows然后啟用虛擬內(nèi)存.
靜態(tài)區(qū):你的常量有多大就多大,
棧,在WINDOWS下,棧的大小是2M(也有的說是1M,總之是一個(gè)編譯時(shí)就確定的常數(shù)),
如果申請的空間超過棧的剩余空間時(shí),將提示overflow。因此,能從棧獲得的空間較小。
堆呢?堆就不是。
堆是不連續(xù)的內(nèi)存區(qū)域。這是由于系統(tǒng)是用鏈表來存儲的空閑內(nèi)存地址的,自然是不連續(xù)的,
而鏈表的遍歷方向是由低地址向高地址。堆的大小受限于計(jì)算機(jī)系統(tǒng)中有效的 虛擬內(nèi)存 。由此可見,堆獲得的空間比較靈活,也比較大。
字面值常量保存在常量區(qū),和靜態(tài)變量保存在靜態(tài)區(qū)不一樣
另外還有代碼區(qū),存放函數(shù)二進(jìn)制代碼。