C语言函数调用 内存关系

Screen Shot 2017-06-10 at 4.37.59 PM.png

该函数内存关系如下。


Screen Shot 2017-06-10 at 4.37.33 PM.png
大致步骤如下

1.先从右到左将b,a的值压栈,将main函数的esp栈顶确定。
2.再执行foo函数之前,先把foo函数执行完后的下一步指令,80483e9(就是函数中return 0)压栈。
3.修改程序计数器eip,然后跳转到foo函数。让ebp栈底寄存器现在指向foo函数,再将main函数栈底的值ebp(main)压栈。此刻,foo函数栈上第一个内存空间保存的是main函数的栈底值。
4.将d,c的值压栈,然后确定foo函数esp栈顶。
5.再执行bar函数之前,先把bar函数执行完后的下一步指令,80483c2(foo的返回指令,返回到main函数)压栈。
6.修改程序计数器eip,然后跳转到bar函数。
7.当bar函数返回了e值之后,会修改程序计数器eip,然后执行80483c2,返回到main函数。然后继续修改程序计数器eip,执行80483e9(return 0)。ebp和esp的值也相应变化。

《C程序设计》一书中对于函数之间调用提出两个注意点:

  • 函数运行期间调用另外一个函数,在运行被调用函数之前,系统需要先完成3件事情:
    1.将所有的实参、返回地址等信息传递给被调用函数保存
    2.为被调用函数局部变量在栈上分配内存
    3.将控制转移到被调用函数入口
  • 被调用函数返回调用函数之前,系统也需要相应的完成3件事情:
    1.在栈中保存被调用函数的计算结果(返回值)
    2.释放在栈中为被调用函数分配的数据区
    3.依照被调用函数保存的返回地址将控制转移到调用函数
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 原文地址:C语言函数调用栈(一)C语言函数调用栈(二) 0 引言 程序的执行过程可看作连续的函数调用。当一个函数执...
    小猪啊呜阅读 4,704评论 1 19
  • 栈: 在函数调用时,第一个进栈的是主函数中函数调用后的下一条指令(函数调用语句的下一条可执行语句)的地址,然后是函...
    zjfclimin阅读 4,102评论 0 5
  • 首先寄存器使用惯例:eip :指令地址寄存器,保存程序计数器的值,当前执行的指令的下一条指令的地址值,16位中为i...
    扎Zn了老Fe阅读 2,013评论 0 0
  • 从本篇开始,我们讨论一些高级语言中的基础设施:堆栈,函数调用,变量生命周期等等话题。因为这里本身会涉及到比较多的汇...
    SlayerNux阅读 13,146评论 1 27
  • “我说你们都怎么办事的。” 严林刚刚听到自己下属汇报的第一个字就面露不悦,在背后四尉的白眼之中,那位人高马大的内联...
    Mod模君阅读 220评论 0 0