汇编
寄存器
esp: 存储栈帧顶部
ebp: 存储栈帧底部指针
rip: 指令计数器 指向下一条执行指令的地址 类似计组中的pc
函数调用过程
当执行call指令时 会将下一条执行的指令压入栈 并将rip寄存器修改为跳转函数的地址
当调用ret命令是 将之前保存的rip出栈 并设置rip
push ebp
mov ebp,esp
将被调用者的栈顶指针保存到栈区 用于调用完成后恢复
第二条命令 将栈顶指针作为函数栈帧的栈底 用于存储函数调用所需的局部变量 函数调用完成后释放这个栈内存 并将之前在栈区保存的栈顶指针恢复
程序调用前的esp和ebp
当程序进行函数调用时
栈底指针修改为函数调用的栈顶指针
当调用完成时 将之前保存的ebp弹栈恢复
虽然道路是曲折的,但前途是光明的。