從匯編看c++中extern關(guān)鍵字的使用
在c++中,extern關(guān)鍵字用來聲明變量和函數(shù),在聲明函數(shù)的時候,有和沒有extern的效果一樣,即下面兩條語句具有同樣的效果:
extern void fun();
void fun();
但是對于變量,有和沒有extern就有區(qū)別,當(dāng)有extern時,只是告知編譯器存在這個變量,編譯器并不為該變量分配存儲空間,即真正的聲明;若沒有extern,則在聲明的同時,編譯器也為該變量分配存儲空間。
下面是有extern的情形時的c++源碼:
int main() {
extern int i;
}
下面是對應(yīng)的匯編碼:
; 1 : int main() {
push ebp
mov ebp, esp;esp為指向棧頂?shù)囊粋€寄存器,始終指向棧頂 ebp也是一個寄存器,用來在給main函數(shù)分配的??臻g上尋訪局部變量,因此常常作為基址
;上面兩句的作用是將前一個棧的基址保存(壓棧),然后讓ebp指向當(dāng)前函數(shù)的??臻g,再次作為基址
; 2 : extern int i;
; 3 : }
xor eax, eax
pop ebp
ret 0;這三句是用來退棧用,以及函數(shù)的返回
從上面的匯編碼可以看出,并沒有為變量i在站上分配任何存儲空間
下面是沒有extern的情形的c++源碼:
int main() {
int i;
}
下面是對應(yīng)的匯編碼:
; 1 : int main() {
push ebp
mov ebp, esp
push ecx;與有extern時的最大的不同就是這一句
;ecx也是一個寄存器,這里講ecx的值壓棧,等同于為變量i在棧上分配了存儲空間
;由于ecx中的值不確定,因此,如果我們訪問沒有初始化的局部變量,常常得到一個奇怪的值
; 2 : int i;
; 3 : }
xor eax, eax
mov esp, ebp
pop ebp
ret 0
可以看出,沒有extern關(guān)鍵字時,確實為變量i在棧上分配了存儲空間
上面的匯編使用cl指令在命令行產(chǎn)生的,如果用vs2010來產(chǎn)生匯編碼,匯編碼可能不一樣,但意思是一樣的。
相關(guān)文章
STL priority_queue(優(yōu)先隊列)詳解
這篇文章主要介紹了 STL priority_queue(優(yōu)先隊列)詳解的相關(guān)資料,需要的朋友可以參考下2016-10-10基于c++強制類型轉(zhuǎn)換的(總結(jié))詳解
本篇文章對C++中的強制類型轉(zhuǎn)換進行了詳細(xì)的分析介紹。需要的朋友參考下2013-05-05關(guān)于C語言 const 和 define 區(qū)別
這篇文章主要介紹了關(guān)于C語言 const 和 define 區(qū)別 的相關(guān)資料,需要的朋友可以參考下面文章內(nèi)容2021-09-09C語言編程技巧 關(guān)于const和#define的區(qū)別心得
盡量用const和inline而不用#define 這個條款最好稱為:“盡量用編譯器而不用預(yù)處理”,因為#define經(jīng)常被認(rèn)為好象不是語言本身的一部分。這是問題之一。再看下面的語句:2013-02-02C++ 中"priority_queue" 優(yōu)先級隊列實例詳解
這篇文章主要介紹了C++ 中"priority_queue" 優(yōu)先級隊列實例詳解的相關(guān)資料,需要的朋友可以參考下2017-04-04