从汇编看c++的extern关键字
添加时间:2013-5-5 点击量:
在c++中,extern关键字用来声明变量和函数,在声明函数的时辰,有和没有extern的结果一样,即下面两条语句具有同样的结果:
extern void fun();
void fun();
然则对于变量,有和没有extern就有差别,当有extern时,只是告诉编译器存在这个变量,编译器并不为该变量分派存储空间,即真正的声明;若没有extern,则在声明的同时,编译器也为该变量分派存储空间。
下面是有extern的景象时的c++源码:
int main() {
extern int i;
}
下面是对应的汇编码:
; 1 : int main() {
push ebp
mov ebp, esp;esp为指向栈顶的一个存放器,始终指向栈顶 ebp也是一个存放器,用来在给main函数分派的栈空间上寻访局部变量,是以经常作为基址
;上方两句的感化是将前一个栈的基址保存(压栈),然后让ebp指向当前函数的栈空间,再次作为基址
; 2 : extern int i;
; 3 : }
xor eax, eax
pop ebp
ret 0;这三句是用来退栈用,以及函数的返回
从上方的汇编码可以看出,并没有为变量i在站上分派任何存储空间
下面是没有extern的景象的c++源码:
int main() {
int i;
}
下面是对应的汇编码:
; 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关键字时,确切为变量i在栈上分派了存储空间
上方的汇编应用cl指令在号令行产生的,若是用vs2010来产生汇编码,汇编码可能不一样,但意思是一样的。
在c++中,extern关键字用来声明变量和函数,在声明函数的时辰,有和没有extern的结果一样,即下面两条语句具有同样的结果:
extern void fun();
void fun();
然则对于变量,有和没有extern就有差别,当有extern时,只是告诉编译器存在这个变量,编译器并不为该变量分派存储空间,即真正的声明;若没有extern,则在声明的同时,编译器也为该变量分派存储空间。
下面是有extern的景象时的c++源码:
int main() {
extern int i;
}
下面是对应的汇编码:
; 1 : int main() {
push ebp
mov ebp, esp;esp为指向栈顶的一个存放器,始终指向栈顶 ebp也是一个存放器,用来在给main函数分派的栈空间上寻访局部变量,是以经常作为基址
;上方两句的感化是将前一个栈的基址保存(压栈),然后让ebp指向当前函数的栈空间,再次作为基址
; 2 : extern int i;
; 3 : }
xor eax, eax
pop ebp
ret 0;这三句是用来退栈用,以及函数的返回
从上方的汇编码可以看出,并没有为变量i在站上分派任何存储空间
下面是没有extern的景象的c++源码:
int main() {
int i;
}
下面是对应的汇编码:
; 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关键字时,确切为变量i在栈上分派了存储空间
上方的汇编应用cl指令在号令行产生的,若是用vs2010来产生汇编码,汇编码可能不一样,但意思是一样的。