1.cpu中的寄存器:
通用寄存器:EAX,EBX,ECX,EDX
程序计数器(EIP(PC)):存放当前正在执行的指令的下一条指令的地址。
栈顶:ESP寄存器
栈底:EBP寄存器
2.将内存中的指令复制到CPU中:
读取指令--->分析指令--->执行指令
3.什么是栈?
>栈是一种特殊的链表形式的数据结构,只允许在链表的一端进行添加和删除。
>栈有栈底和栈顶。从栈顶入栈称为push,从栈底入栈称为pop。
>栈是先进后出,后进先出
4.什么 是栈帧?
下面我们看一个代码:
#include<stdio.h>
#include<windows.h>
int add(int x,int y)
{
int z=0;
z=x+y;
return z;
}
int main()
{ int a=10;
int b=20;
int ret=add(a,b);
printf("ret=%d\n",ret);
system("pause");
return 0;
}
(1)每一次函数调用都是一个过程这个过程我们称为函数的调用过程,这个过程要为函数开辟栈空间,用于本次函数的调用中临时变量的保存,现场保护。这块栈空间我们称为函数栈帧
(2)寄存器ebp:称为“基址指针”:指向函数帧栈底的地址。
寄存器esp:称为“栈指针”:指向函数栈帧栈顶的地址。
比如调用main函数分配栈空间:
(3)当我们要详细研究函数调用过程,必须得对照的汇编代码。
从main函数的地方开始,要展开main函数的调用就得为main函数创建栈帧。