- 论坛徽章:
- 0
|
如果你懂汇编的话就很理解了。
局部变量是在栈中的,也就是当你调用函数的时候才分配的。
2个例子:
void a()
{
int i;
i = 0;
} |
----------------------dasm-----------------
void a()
;{
push ebp ;保存当前的ebp寄存器
mov ebp, esp ;ebp中保存当前的栈偏移
; int i
sub esp, 4 ;栈偏移-4 即给出一个sizeof(int)大小的栈空间此时的SS:[esp]就是变量i的地址
; i = 0;
xor eax, eax
mov SS:[ebp - 4], eax
;}
add esp, 4 ;还原为变量i预留的栈空间
pop ebp ;还原之前的ebp寄存器 |
|
void b()
{
int ia[4];
ia[0] = ia[1] = ia[2] = ia[3] = 0;
} |
----------------------dasm-----------------
void b()
;{
push ebp ;保存当前的ebp寄存器
mov ebp, esp ;ebp中保存当前的栈偏移
; int ia[4];
sub esp, 0x10 ;栈偏移-16 即给出一个sizeof(int) * 4大小的栈空间此时的SS:[esp]就是变量ia[0]的地址
; ia[0] = ia[1] = ia[2] = ia[3] = 0;
xor eax, eax
mov SS:[ebp - 0x10], eax
mov SS:[ebp - 0x0C], eax
mov SS:[ebp - 8], eax
mov SS:[ebp - 4], eax
;}
add esp, 0x10 ;还原为变量i预留的栈空间
pop ebp ;还原之前的ebp寄存器 |
[ 本帖最后由 tiankunmin 于 2007-9-29 04:19 编辑 ] |
|