1. 概论
假设函数P调用函数Q,Q执行后返回到P。这个调用包括下面一个或多个机制:
- 传递控制:在进入过程Q的时候,PC指针被设置为Q的代码的起始地址,然后Q返回时再把PC设置为P中调用Q后面的那条指令地址。
- 传递数据:P必须能够向Q提供一个或多个参数,Q必须能够向P返回一个值。
- 分配和释放内存:Q可能需要为局部变量分配空间,返回前又必须释放这些空间。
运行时栈的结构如下图:
其中x86-64的栈向低地址方向增长,而栈指针%rsp指向栈顶元素。可以用pushq和popq将数据入栈或者出栈。
2. 传递控制
调用指令是:
指令 | 描述 |
---|---|
call Label | 过程调用 |
call *Operand | 过程调用 |
ret | 从过程中返回 |
实例说明: