mips栈帧详解

通过文档上逐步深入的四个例子,我对栈帧有了更全面的理解:

栈帧是运行时逐步产生的,而不是在调用其他函数那一刻产生的,对于以下例子

复制代码
 int g( int x, int y ) { 
  int a[32]; 
  ... (calculate using x, y, a); 
  a[1] = f(y,x,a[2],a[3],a[4]); 
  a[0] = f(x,y,a[1],a[2],a[3]); 
  return a[0]; 
 }

现在研究g的栈帧,

蓝色区域用来存此函数的局部变量,如a,会占32个word,也就是128个byte

深绿色区域存储当前函数的返回地址,如果当前函数没有调用其他函数,此区域可以没有

浅绿色区域,当函数g内部逻辑要用到 $s 寄存器时,才会在用之前存储好之前的寄存器值(保留现场)

黄色区域,当第一次调用f时,存储参数,无论用不用寄存器传递,都要在栈帧中存。只要调用其他函数,黄色区域必有四个word,但这四个word是空的,只是为了后序f中可能用到而预留的。

灰色区域,用于padding,使得栈帧大小是8的倍数。

当调用完第一次f之后,会重新构建黄色区域的arg4,重新构建四个 $a 寄存器。

容易混淆的点是:

  1. 栈帧不是调用时的,而是运行时的

  2. 栈帧在调用结束时销毁,指的是被调用的函数的栈帧,如上例子,调用f后f会有自己的栈帧,f运行结束自己的栈帧会销毁,而g的栈帧在最后g运行结束才会销毁

相关推荐
李日灐几秒前
C++进阶必备:红黑树从 0 到 1: 手撕底层,带你搞懂平衡二叉树的平衡逻辑与黑高检验
开发语言·数据结构·c++·后端·面试·红黑树·自平衡二叉搜索树
Risehuxyc9 分钟前
备份三个PHP程序
android·开发语言·php
lly20240615 分钟前
PHP Error: 常见错误及其解决方法
开发语言
网安墨雨15 分钟前
Python自动化一------pytes与allure结合生成测试报告
开发语言·自动化测试·软件测试·python·职场和发展·自动化
毕设源码李师姐18 分钟前
计算机毕设 java 基于 java 的图书馆借阅系统 智能图书馆借阅综合管理平台 基于 Java 的图书借阅与信息管理系统
java·开发语言·课程设计
忆~遂愿18 分钟前
Runtime 上下文管理:计算实例的生命周期、延迟最小化与上下文切换优化
java·大数据·开发语言·人工智能·docker
沐知全栈开发19 分钟前
PostgreSQL中的AND和OR操作符
开发语言
一战成名99621 分钟前
深度解析 CANN 模型转换工具链:从 ONNX 到 OM
人工智能·学习·安全·开源
1尢晞124 分钟前
Java学习
java·开发语言
毕设源码-赖学姐32 分钟前
【开题答辩全过程】以 基于python的电影推荐系统为例,包含答辩的问题和答案
开发语言·python