以前接触程序时,只知道程序写的对,一般都能运行出来,但是却不知道程序是怎么一步一步将每一步编译链接起来的,今天我们用汇编来看一下程序到底是怎么在程序中运行的。
#include <stdio.h>
int Add(int x,int y)
{
int sum = 0;
sum = x+y;
return sum;
}
int main()
{
int a = 2;
int b = 3;
int ret = Add(a,b);
printf("%d\n",ret);
return 0;
}
我们在写程序的时候都是先写main函数,知道main函数是系统函数,直接调用就行。但是,实际上main函数是被三个其他的函数一次调用而来的,而程序在执行的时候会依次给main函数开辟一块内存,然后在根据我们写的程序依次以堆栈的形式在这块内存上存取数据。如此一来,我们队程序的调用就可以清楚明确的了解了。
在调试的过程中,我们转到反汇编写来看看。在调用main函数之后,系统先将ebp(栈底指针)和esp(栈顶指针)压入到一块堆栈中(运行时堆栈,又叫栈帧),然后是esp与4cH想减(即把esp指针向上挪4c空间大小),再将ebx,esi,edi分别压到
堆栈中,经过le啊,mov,mov三条之令之后,main函数的初始空间就被填充成了13h(二进制位19)个cc