亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

c語言stack(棧)和heap(堆)的使用詳解

2020-01-26 15:33:01
字體:
來源:轉載
供稿:網友

一、預備知識―程序的內存分配

一個由C/C++編譯的程序占用的內存分為以下幾個部分

1、棧區(stack)―由編譯器自動分配釋放,存放函數的參數值,局部變量的值等。其操作方式類似于數據結構中的棧。
2、堆區(heap)―一般由程序員分配釋放,若程序員不釋放,程序結束時可能由OS回收。注意它與數據結構中的堆是兩回事,分配方式倒是類似于鏈表。
3、全局區(靜態區)(static)―全局變量和靜態變量的存儲是放在一塊的,初始化的全局變量和靜態變量在一塊區域,未初始化的全局變量和未初始化的靜態變量在相鄰的另一塊區域。程序結束后由系統釋放。
4、文字常量區―常量字符串就是放在這里的。程序結束后由系統釋放。
5、程序代碼區―存放函數體的二進制代碼。

二、例子程序

復制代碼 代碼如下:

//main.cpp
 int a=0;  //全局初始化區
 char *p1;  //全局未初始化區
 main()
 {
  intb;棧
  char s[]="abc";  //棧
  char *p2;     //棧
  char *p3="123456";  //123456/0在常量區,p3在棧上。
  static int c=0;  //全局(靜態)初始化區
  p1 = (char*)malloc(10);
  p2 = (char*)malloc(20);  //分配得來得10和20字節的區域就在堆區。
  strcpy(p1,"123456");  //123456/0放在常量區,編譯器可能會將它與p3所向"123456"優化成一個地方。
}

三、堆和棧的理論知識
2.1申請方式
stack:
由系統自動分配。例如,聲明在函數中一個局部變量int b;系統自動在棧中為b開辟空間

heap:
 需要程序員自己申請,并指明大小,在c中用malloc函數
如p1=(char*)malloc(10);
在C++中用new運算符
如p2=(char*)malloc(10);
但是注意p1、p2本身是在棧中的。

2.2申請后系統的響應
棧:只要棧的剩余空間大于所申請空間,系統將為程序提供內存,否則將報異常提示棧溢出。
堆:首先應該知道操作系統有一個記錄空閑內存地址的鏈表,當系統收到程序的申請時,會遍歷該鏈表,尋找第一個空間大于所申請空間的堆結點,然后將該結點從空閑結點鏈表中刪除,并將該結點的空間分配給程序,另外,對于大多數系統,會在這塊內存空間中的首地址處記錄本次分配的大小,這樣,代碼中的delete語句才能正確的釋放本內存空間。另外,由于找到的堆結點的大小不一定正好等于申請的大小,系統會自動的將多余的那部分重新放入空閑鏈表中。

2.3申請大小的限制
棧:在Windows下,棧是向低地址擴展的數據結構,是一塊連續的內存的區域。這句話的意思是棧頂的地址和棧的最大容量是系統預先規定好的,在WINDOWS下,棧的大小是2M(也有的說是1M,總之是一個 編譯時就確定的常數),如果申請的空間超過棧的剩余空間時,將提示overflow。因此,能從棧獲得的空間較小。
堆:堆是向高地址擴展的數據結構,是不連續的內存區域。這是由于系統是用鏈表來存儲空閑內存地址的,自然是不連續的,而鏈表的遍歷方向是由低地址向高地址。堆的大小受限于計算機系統中有效的虛擬內存。由此可見,堆獲得的空間比較靈活,也比較大。

2.4申請效率的比較:
棧:由系統自動分配,速度較快。但程序員是無法控制的。
堆:是由new分配的內存,一般速度比較慢,而且容易產生內存碎片,不過用起來最方便。另外,在WINDOWS下,最好的方式是用Virtual Alloc分配內存,他不是在堆,也不是在棧,而是直接在進程的地址空間中保留一塊內存,雖然用起來最不方便。但是速度快,也最靈活。

2.5堆和棧中的存儲內容
棧:在函數調用時,第一個進棧的是主函數中后的下一條指令(函數調用語句的下一條可執行語句)的地址,然后是函數的各個參數,在大多數的C編譯器中,參數是由右往左入棧的,然后是函數中的局部變量。注意靜態變量是不入棧的。當本次函數調用結束后,局部變量先出棧,然后是參數,最后棧頂指針指向最開始存的地址,也就是主函數中的下一條指令,程序由該點繼續運行。
堆:一般是在堆的頭部用一個字節存放堆的大小。堆中的具體內容由程序員安排。

2.6存取效率的比較

復制代碼 代碼如下:

char s1[]="aaaaaaaaaaaaaaa";
char *s2="bbbbbbbbbbbbbbbbb";
aaaaaaaaaaa是在運行時刻賦值的;而bbbbbbbbbbb是在編譯時就確定的;但是,在以后的存取中,在棧上的數組比指針所指向的字符串(例如堆)快。比如:
#include
int main()
{
char a=1;
char c[]="1234567890";
char *p="1234567890";
a = c[1];
a = p[1];
return 1;
}

對應的匯編代碼

復制代碼 代碼如下:

10:a=c[1];
004010678A4DF1movcl,byteptr[ebp-0Fh]
0040106A884DFCmovbyteptr[ebp-4],cl
11:a=p[1];
0040106D8B55ECmovedx,dwordptr[ebp-14h]
004010708A4201moval,byteptr[edx+1]
004010738845FCmovbyteptr[ebp-4],al

第一種在讀取時直接就把字符串中的元素讀到寄存器cl中,而第二種則要先把指針值讀到edx中,在根據edx讀取字符,顯然慢了。
2.7小結
堆和棧的區別可以用如下的比喻來看出:使用棧就象我們去飯館里吃飯,只管點菜(發出申請)、付錢、和吃(使用),吃飽了就走,不必理會切菜、洗菜等準備工作和洗碗、刷鍋等掃尾工作,他的好處是快捷,但是自由度小。使用堆就象是自己動手做喜歡吃的菜肴,比較麻煩,但是比較符合自己的口味,而且自由度大。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
中文字幕日本精品| 欧美午夜激情视频| 日韩在线免费视频观看| 亚洲一二在线观看| 精品国产依人香蕉在线精品| 亚洲曰本av电影| 最新亚洲国产精品| 欧美日韩亚洲网| 日韩av一区在线观看| 欧美午夜视频在线观看| 欧美成人h版在线观看| 欧美精品久久久久久久免费观看| 国产欧美va欧美va香蕉在线| 日韩国产高清视频在线| 国产色视频一区| 成人h视频在线观看播放| 91黑丝高跟在线| 欧美在线视频网| 久久免费精品视频| 欧美高清视频在线播放| 欧美激情视频免费观看| 亚洲图片欧美午夜| 欧美中文字幕在线观看| 亚洲一区二区三区xxx视频| 国产+成+人+亚洲欧洲| 亚洲精品免费一区二区三区| 亚洲成人av在线| 最近2019年日本中文免费字幕| 日韩欧美黄色动漫| 97在线看免费观看视频在线观看| 91国内在线视频| 91高潮精品免费porn| 成人免费淫片aa视频免费| 欧美性猛交xxxx免费看漫画| 久久国内精品一国内精品| 热99精品里视频精品| 欧美国产欧美亚洲国产日韩mv天天看完整| 奇米影视亚洲狠狠色| 91在线高清视频| 一区国产精品视频| 久久99热这里只有精品国产| 青青在线视频一区二区三区| 日韩电影中文字幕av| 欧美激情成人在线视频| 日韩欧美黄色动漫| 国产精品视频一| 久久影院免费观看| 超碰91人人草人人干| 日本在线精品视频| 亚洲精品电影在线| 欧美激情综合色综合啪啪五月| 国产精品av电影| 日韩av成人在线观看| 色樱桃影院亚洲精品影院| 国产亚洲激情视频在线| 人人澡人人澡人人看欧美| 亚洲欧美综合精品久久成人| 97香蕉超级碰碰久久免费的优势| 久久精品视频免费播放| 久久久久久久国产精品视频| 亚洲国产高清高潮精品美女| 国产精品永久在线| 日本三级韩国三级久久| 国产精品成熟老女人| 亚洲九九九在线观看| 久久久久久午夜| 这里只有精品丝袜| 国产成人福利视频| 亚洲人精选亚洲人成在线| 亚洲国产精品久久久久| 国产视频精品自拍| 欧美伊久线香蕉线新在线| 亚洲日本中文字幕| 精品国产福利视频| 欧美日韩免费观看中文| 欧美黑人视频一区| 色婷婷久久一区二区| 亚洲精品久久久久中文字幕欢迎你| 中文字幕无线精品亚洲乱码一区| 久久亚洲综合国产精品99麻豆精品福利| 日韩激情av在线播放| 岛国av在线不卡| 久久精品国产久精国产思思| 日本久久久a级免费| 在线播放精品一区二区三区| 国模极品一区二区三区| www.99久久热国产日韩欧美.com| 亚洲国产欧美日韩精品| 日韩精品在线观| 久久久精品国产| 国产亚洲视频中文字幕视频| 最近2019中文字幕大全第二页| 韩剧1988免费观看全集| 精品久久久91| 国产精品高潮在线| 精品中文字幕在线| 北条麻妃99精品青青久久| 国外成人在线播放| 在线成人中文字幕| 欧美理论电影在线观看| 国产精品激情av电影在线观看| 国产精品尤物福利片在线观看| 一区二区三区黄色| 国产美女精品视频| 亚洲国产精品成人一区二区| 在线中文字幕日韩| 成人免费在线视频网站| 狠狠色香婷婷久久亚洲精品| 国产欧美久久一区二区| 国产精品99久久久久久久久| 最近2019好看的中文字幕免费| 国内精品久久久久伊人av| 日韩av网址在线| 国产精品三级在线| 国产精品a久久久久久| 精品久久久香蕉免费精品视频| 日韩电视剧免费观看网站| 国产精品自产拍在线观看| 亚洲人午夜色婷婷| 中文字幕在线观看日韩| 欧美在线视频在线播放完整版免费观看| 97视频在线免费观看| 国产精品综合不卡av| 亚洲综合日韩在线| 国产精品对白刺激| 少妇高潮久久久久久潘金莲| 亚洲最大av在线| 日韩在线视频免费观看| 日韩精品中文在线观看| 97久久精品视频| 91精品国产一区| 亚洲欧美日韩精品| 精品久久久久久久久久国产| 中文字幕不卡在线视频极品| 久久久91精品| 欧美电影免费观看网站| 亚洲国产精品va在看黑人| 日韩最新在线视频| 国产网站欧美日韩免费精品在线观看| 国产成人精品视频| 在线视频中文亚洲| 91免费国产网站| 久久理论片午夜琪琪电影网| 91久久精品国产| 色综合老司机第九色激情| 日韩免费在线看| 亚洲国产精品99| 高清欧美性猛交xxxx| 亚洲国产小视频| 久久精品国产v日韩v亚洲| 亚洲在线视频观看| 97碰碰碰免费色视频| 动漫精品一区二区| 91性高湖久久久久久久久_久久99| 57pao国产精品一区| 国产91在线视频| 亚洲国产精品久久精品怡红院| 91精品在线观看视频| 韩国三级电影久久久久久| 久久夜色精品亚洲噜噜国产mv| 色爱av美腿丝袜综合粉嫩av| 欧美视频精品一区| 久久久久久国产免费| 亚洲精品日韩激情在线电影|