堆與棧儲存效率的一點理解

2021-08-26 10:02:23 字數 993 閱讀 9387

還是引用這個經典的例子:

#include

void main()

整個**的反彙編**如下:

1: #include

2: void main()

3: 00401066 pop edi

00401067 pop esi

00401068 pop ebx

00401069 mov esp,ebp

0040106b pop ebp

0040106c ret

這裡「1234567890」是乙個字串常量,存放的位置在常量資料區(既不是堆也不是棧),此處的位址為0042201c

也就是說編譯的時候這個字串常量已經確定了,

針對這個例子

charc="1234567890";

char*p="1234567890";

前後兩個「1234567890」就是同乙個字串常量,存放在編譯時確定的常量資料區里,

執行的時候再用這個常量字串對c賦值,而第二種使用的時候先把指標值讀到edx中,再根據edx讀取字元。

如果換成下面的例子:

charc="aaaaa";

char*p="1234567890";

因為兩個字串不同,就存在常量資料區的不同位置。

彙編部分如下:

5: char c = "aaaaa";

0040102c mov eax,[string "aaaaa" (00422028)]

00401031 mov dword ptr [ebp-0ch],eax

00401034 mov cx,word ptr [string "aaaaa"+4 (0042202c)]

0040103b mov word ptr [ebp-8],cx

6: char *p ="1234567890";

0040103f mov dword ptr [ebp-10h],offset string "1234567890" (0042201c)

堆和棧的一點區別

五大記憶體分割槽 在c 中,記憶體分成5個區,他們分別是堆 棧 自由儲存區 全域性 靜態儲存區和常量儲存區。棧,就是那些由編譯器在需要的時候分配,在不需要的時候自動清楚的變數的儲存區。裡面的變數通常是區域性變數 函式引數等。堆,就是那些由new分配的記憶體塊,他們的釋放編譯器不去管,由我們的應用程式...

關於堆和棧的一點知識

一 預備知識 程式的記憶體分配 乙個由c c 編譯的程式占用的記憶體分為以下幾個部分 1 棧區 stack 由編譯器自動分配釋放 存放函式的引數值,區域性變數的值等。其 操作方式類似於資料結構中的棧。2 堆區 heap 一般由程式設計師分配釋放,若程式設計師不釋放,程式結束時可能由os回 收 注意它...

UIWebView 的一點理解

uiwebview可以用來方便得顯示url request uiwebview 是從uiview繼承而來的。所以本身並沒有實現scroll。當開啟乙個urlrequest之後,uiwebview 自動建立乙個uiscrollview add 到uiwebview的layer 當開啟當前頁面中的lin...