Bootstrap

c语言中函数调用的过程

一.程序在内存中的占用。

要学习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。


到这里函数的调用就结束了。





悦读

道可道,非常道;名可名,非常名。 无名,天地之始,有名,万物之母。 故常无欲,以观其妙,常有欲,以观其徼。 此两者,同出而异名,同谓之玄,玄之又玄,众妙之门。

;