栈帧浅析,堆栈漏洞概述——【太原理工大学软件安全期末补充】

在上一篇文章中我说实验一不重要,确实没必要完全按照实验内容逐字逐句理解,但是这里我们补充一个知识点

栈帧(Stack Frame)是计算机程序执行过程中,调用栈(Call Stack)中的一个单元,它包含了函数调用时的上下文信息。每当一个函数被调用时,一个新的栈帧就会被创建并被推入调用栈。栈帧通常包含以下信息:

1. **返回地址**:函数执行完毕后,控制权返回到调用者的地方的地址。
2. **局部变量**:函数内部定义的局部变量,它们只在函数的作用域内可见。
3. **参数**:传递给函数的参数值。
4. **寄存器保存**:在某些情况下,函数调用可能会保存一些寄存器的值,以确保它们在函数执行期间不会被覆盖。
5. **栈指针**:指向当前栈帧的指针。

当函数执行结束时,它的栈帧会被弹出调用栈,控制权和状态会恢复到调用它的函数的栈帧。这个过程是程序流程控制的基础之一,确保了函数调用的有序性和数据的隔离性。

缓冲区

程序中所使用的缓冲区可以是堆区和栈区,也可以是存放静态变量的数据区。

### 栈溢出(Stack Overflow)
1. **定义**:栈溢出发生在程序的调用栈超出其分配的内存空间时。调用栈用于存储函数调用的上下文信息,包括局部变量、参数、返回地址等。
2. **原因**:通常是由于递归调用太深或循环调用太频繁,导致栈空间被耗尽。

### 堆溢出(Heap Overflow)
1. **定义**:堆溢出发生在程序的堆内存超出其分配的内存空间时。堆用于动态内存分配,存储程序运行时创建的对象和数据结构。
2. **原因**:可能由于程序中存在内存泄漏(未释放不再使用的对象),或者分配了过大的内存块,导致堆空间耗尽。

就这些,不多。

  • 19
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值