原码如下:
#include <stdio.h>
#pragma warning (disable:(4996))
int Add(int x,int y)
{
int sum = 0;
sum = x+y;
return (sum);
}
int main()
{
int a = 2;
int b = 3;
int ret = 0;
ret = Add(a,b);
return 0;
}
基本的汇编指令:
esp:esp寄存器里存储的是在调用函数之后,栈的栈顶。并且始终指向栈顶。
ebp:ebp寄存器里存储的是是栈的栈底指针,通常叫栈基址,这个是一开始进行函数调用之前,由esp传递给ebp的。(在函数调用前你可以这么理解:esp存储的是栈顶地址,也是栈底地址。)
push:压入操作,把一个32位的操作数压入堆栈中,这个操作在32位机中会使得esp被减4(字节),esp通常是指向栈顶的,这里顶部是地址小的区域,那么,压入堆栈的数据越多,esp也就越来越小
mov:数据传送。第一个参数是目的操作数,第二个参数是源操作数,就是把源操作数拷贝到目的一份。