函数的调用(汇编代码分析)

1.sum函数调用完为什么会回退到main函数的调用栈针上。
2.为什么调用完后会从下一行执行。
3.值是怎么传递的,是形参开辟内存,还是实参开辟。

# include<stdio.h>
int sum(int first,int second)
{
	int tmp;
	tmp = first+second;
	return tmp;
}

int main()
{
	int a = 10;
	int b = 20;
	int rt = sum(a,b);
	return 0;
}

1.设置断点,启动debug模式。
2.调试-》窗口-》反汇编得到下图所示汇编代码。
在这里插入图片描述
分析汇编代码:
push:压栈
pop:出栈,把栈上数据给寄存器
call:1.压入下一行地址,2,jump跳转到(sum)函数栈顶
mov:把数值移动到寄存器
lea:挪指针
add:累加
sub:减
pc寄存器:存放一条指令的地址。
寄存器入栈,相当于在栈顶开辟内存,这块内存即为形参地址空间。
eax ebx ecx是存放数值的寄存器。
ebp栈底指针寄存器
esp栈顶指针寄存器
参数传递的方向:从右向左。函数的返回值由寄存器带回。

在这里插入图片描述
形参开辟内存在main函数上。

猜你喜欢

转载自blog.csdn.net/qq_42111463/article/details/84147360