以上两张图做了四件事情:
(1)将调用方的栈底指针入栈.
(2)让原本指向调用方栈底的ebp指向当前函数的栈底.
(3)给当前函数开辟栈帧.
(4)对开辟的栈帧进行初始化.
总结:
函数的运行都是在栈上开辟内存的.
栈是通过esp(栈顶指针),ebp(栈底指针)两个指针来标识的
对于栈上的访问都是通过栈底指针的偏移来访问的
在call一个函数时,有两件事情:先将调用函数的下一行指令的地址压入栈中,再进行跳转.
在函数调用时检查函数是否声明,函数名是否相同,函数的参数列表是否匹配,函数的返回值多大.
(1)如果(函数的返回值<=4个字节),则返回值通过寄存器eax带回.
(2)如果(4<函数的返回值<=8个字节),则返回值通过两个寄存器eax和edx带回.
(3)如果(函数的返回值>8个字节),则返回值通过产生的临时量带回.
6.函数结束ret指令干了两件事:先出栈,再将栈的值放到CPU的PC寄存器中,因为PC寄存器中永远放的是下一次执行指令的地址,所以就在函数调用完之后依旧接着原来的代码继续执行.