汇编

寄存器

esp: 存储栈帧顶部
ebp: 存储栈帧底部指针
rip: 指令计数器 指向下一条执行指令的地址 类似计组中的pc

函数调用过程

当执行call指令时 会将下一条执行的指令压入栈 并将rip寄存器修改为跳转函数的地址
当调用ret命令是 将之前保存的rip出栈 并设置rip

push ebp
mov ebp,esp
将被调用者的栈顶指针保存到栈区 用于调用完成后恢复
第二条命令 将栈顶指针作为函数栈帧的栈底 用于存储函数调用所需的局部变量 函数调用完成后释放这个栈内存 并将之前在栈区保存的栈顶指针恢复
程序调用前的esp和ebp
image
当程序进行函数调用时
image
栈底指针修改为函数调用的栈顶指针
当调用完成时 将之前保存的ebp弹栈恢复
image

posted @ 2021-11-13 11:10  RainbowMagic  阅读(68)  评论(0)    收藏  举报