[Modern Compiler] Activation Records: Stack Frames

下图为一个典型的编译器的各个阶段,每个阶段由一至多个软件模块来实现。
Phases&Interfaces
更详细内容可以查看[Modern Compiler] Introduction

活动记录

栈(stack):一个有序的积累或堆积。

函数的局部变量在函数入口创建,在函数的出口删除。函数调用是按后进先出(LIFO)方式进行,所以使用栈存放他们。

函数内的局部变量需要的生命周期超过函数本身的生命期:

  1. 嵌套函数:内层函数可能会用到外层函数中定义的变量。
  2. 将函数作为返回值:保存在变量中的函数。

栈帧

抽象的push、pop并不合适:局部变量成批push,成批pop。当其在栈中被创建时,没有被立刻初始化,并且有可能访问压在栈顶之下较深的变量。

替代:把栈看成一个大型数组,带有一个栈指针(寄存器),指向栈内的某个存储单元。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值