国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 編程 > C++ > 正文

關(guān)于C++使用指針 堆和棧的區(qū)別分析

2020-01-26 16:19:16
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

數(shù)據(jù)在內(nèi)存的存放有以下幾種形式

1.棧區(qū)--由編譯器自動(dòng)分配并且釋放,該區(qū)域一般存放函數(shù)的參數(shù)值,局部變量的值等,
2.堆區(qū)--一般由程序員分配釋放,如果程序員不釋放,程序結(jié)束的時(shí)候才會(huì)被操作系統(tǒng)回收,
3.寄存器區(qū)--用來(lái)保存棧頂指針和指令指針
4.全局去--也是靜態(tài)區(qū),全局變量和靜態(tài)變量都是存儲(chǔ)在一起的,初始化的全局變量和靜態(tài)變量都存儲(chǔ)在一塊,為初始化的全局變量和靜態(tài)變量在相鄰的另一個(gè)區(qū)域,程序結(jié)束后由系統(tǒng)釋放。
5.文字常量區(qū)--常量字符串就是放在這里的,程序結(jié)束后由系統(tǒng)釋放,
6.程序代碼區(qū)--存放函數(shù)的二進(jìn)制代碼。

函數(shù)參數(shù)和局部變量存放在棧中,函數(shù)運(yùn)行結(jié)束或者返回系統(tǒng)就釋放了他們所占用的內(nèi)存空間,但是全局變量不會(huì)被系統(tǒng)釋放掉。全局的只有在程序結(jié)束后才會(huì)被系統(tǒng)所釋放,而且由于全局變量被所有的類成員和函數(shù)所共享,很容易被修改,為了解決這一問(wèn)題
我們會(huì)使用堆

堆棧的區(qū)別

1.申請(qǐng)方式的不同

堆是程序員自己申請(qǐng)
而棧則是有程序判斷局部變量或者函數(shù) 系統(tǒng)來(lái)自動(dòng)分配

2.系統(tǒng)的響應(yīng)不同

棧-只要棧的剩余空間大于所申請(qǐng)的空間,系統(tǒng)將為程序提供內(nèi)存,否則將提示棧溢出 overflow

堆- 系統(tǒng)收到程序中申請(qǐng)的控件后,會(huì)遍歷一個(gè)操作系統(tǒng)用來(lái)記錄內(nèi)存控件地址得鏈表,當(dāng)找到一個(gè)空間大于所申請(qǐng)控件的堆結(jié)點(diǎn)后就會(huì)將該節(jié)點(diǎn)從記錄內(nèi)存空閑地址的鏈表中刪除,并將結(jié)點(diǎn)的內(nèi)存分配給程序,然后在這塊區(qū)域的首地址處記錄分配的大小,     這樣我們?cè)谑褂胐elete來(lái)釋放內(nèi)存的時(shí)候,delete才能正確的識(shí)別并刪除該內(nèi)存區(qū)域的所有變量,另外我們申請(qǐng)的內(nèi)存空間與堆結(jié)點(diǎn)上的內(nèi)存空間不一定相等,這時(shí)候系統(tǒng)就會(huì)自動(dòng)將堆結(jié)點(diǎn)上的多出來(lái)的一部分內(nèi)存空間回收到空閑鏈表中

3、空間的大小不同

棧-在windows狀態(tài)下,棧是一塊連續(xù)的內(nèi)存的區(qū)域,它的大小是2M,也有的說(shuō)1M,總之這個(gè)數(shù)值是一編譯的時(shí)候就確定的常數(shù),是由系統(tǒng)預(yù)先根據(jù)棧頂?shù)牡刂泛蜅5淖畲笕萘慷x好的,加入你的數(shù)據(jù)申請(qǐng)的內(nèi)存空間超過(guò)棧的空間,就會(huì)提示overflow,所以別指望棧能夠存儲(chǔ)比較大的數(shù)據(jù)。

堆-堆是不連續(xù)的內(nèi)存區(qū)域,各塊區(qū)域由鏈表將他們串起來(lái),這些串聯(lián)起來(lái)的內(nèi)存空間叫做堆,他的大小是由系統(tǒng)中虛擬的內(nèi)存來(lái)定的,因此獲得的空間比較大,而且獲得空間的方式也比較靈活。

4.執(zhí)行效率的不同

棧-棧由系統(tǒng)自動(dòng)分配,因此速度比較快,但是程序員不能對(duì)其進(jìn)行操作。
堆-堆是程序員分配的內(nèi)存,     一般速度比較慢,而且容易產(chǎn)生內(nèi)存碎片,不過(guò)用起來(lái)很方便。

5.執(zhí)行函數(shù)的不同

棧-在函數(shù)調(diào)用的時(shí)候,第一個(gè)進(jìn)棧的是被調(diào)用函數(shù)下一行的內(nèi)存地址,其次是函數(shù)的參數(shù),假如參數(shù)多余一個(gè),那么次序是從左往右,最后才是函數(shù)的局部變量。

由于棧的先進(jìn)后出原則,函數(shù)結(jié)束時(shí)正好相反,先是局部變量先出棧,然后是參數(shù),次序是從左向右,這時(shí)所偶的變量都出棧,指針自然的第一個(gè)進(jìn)棧的那行內(nèi)存地址,也就是被調(diào)用函數(shù)的下一行內(nèi)存地址,程序根據(jù)該地址跳轉(zhuǎn)到調(diào)用函數(shù)的下一行自動(dòng)執(zhí)行。

由于棧的先進(jìn)后出原則,所以他永遠(yuǎn)不可能產(chǎn)生內(nèi)存碎片

堆--堆是一大堆不連續(xù)的內(nèi)存區(qū)域,在系統(tǒng)中由鏈表將他們串聯(lián)起來(lái),因此在使用的時(shí)候必須由程序員來(lái)安排,他的機(jī)制是很復(fù)雜的,有時(shí)候?yàn)榱朔峙湟粔K合適的內(nèi)存,程序員需要按照一定的算法在堆內(nèi)存中搜索可用的足夠大的空間,如果沒(méi)有滿足條件的空間,那么就要向內(nèi)存中發(fā)出申請(qǐng)一部分內(nèi)存空間,這樣才能有機(jī)會(huì)分配足夠大的內(nèi)存,然后將計(jì)算后的數(shù)值返回,顯然堆的運(yùn)行效率比棧低很多,而且容易產(chǎn)生碎片,但是好處是堆可以存儲(chǔ)相當(dāng)?shù)拇蟮臄?shù)據(jù),并且一些細(xì)節(jié)可以由程序員來(lái)安排。

以上就是堆棧的區(qū)別 但是在應(yīng)用中的取舍還是具體問(wèn)題具體分析

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 石城县| 奉化市| 晋宁县| 蓝田县| 磴口县| 泰安市| 丹寨县| 永城市| 长兴县| 和平县| 锡林浩特市| 阿城市| 兴化市| 平原县| 确山县| 永靖县| 汪清县| 历史| 浮山县| 四子王旗| 赣榆县| 汤阴县| 河津市| 泾源县| 濮阳市| 两当县| 锦州市| 富源县| 泽州县| 左权县| 怀集县| 福安市| 柳江县| 榆林市| 万全县| 斗六市| 广德县| 贺兰县| 洮南市| 龙南县| 永川市|