一.程序在内存中的占用。
要学习C语言中函数调用的过程,必须要知道程序在内存中各个区域的分布。
C语言的函数调用的过程主要分布在栈中,所以我们今天主要研究栈。
二.几个基本的汇编指令。
call:1.将当前指令的下一条指令的地址保存到栈中。
2.跳转至目标函数的地址。
ret :弹出栈顶地址将数据放入eip
从栈顶入栈称为push
从栈底出栈称为pop
三.常用寄存器。
在CPU中:读取指令(内存-->CPU)-->分析指令(CPU)-->执行指令(CPU)
1. EAX:累积暂存器,EBX:基底暂存器,ECX:计数暂存器,EDX:资料暂存器
2. EIP(pc):程序计数器(用来存放当前正在执行指令的下一条指令的地址)
3. ESP:栈顶
4. EBP:栈底
四.函数的调用与栈帧的创建销毁。
实例函数:
转换成汇编语言:
首先由_tmainCRTStartup调用main函数,并在栈中创建了一个栈帧。
分别把a和b的值压入栈中:
创建b,a临时变量压栈。
call指令保存当前指令下一条计数器的值,并跳转到指定地址。
创建新的栈帧myadd
定义z,并计算a+b,并返回z的值到main中
将a+b的值赋给c。
到这里函数的调用就结束了。