单片机/C/C++八股:(十九)栈和堆的区别?

上一篇 下一篇
C/C++ 中 sizeof 和 strlen 的区别

栈和堆的区别?

  1. 内存分配方式

    • :由系统自动分配和释放。函数调用时,局部变量、函数参数等会自动压入栈;函数返回时,这些数据自动弹出并释放。

    • :由程序员手动申请和释放(如 C/C++ 中使用 malloc/freenew/delete)。若不手动释放,可能造成内存泄漏。

  2. 内存管理

    • :遵循"后进先出"(LIFO)原则,结构简单,管理高效。

    • :内存分配自由,可以动态申请任意大小的内存块,但管理复杂,容易产生碎片。

  3. 生命周期

    • :变量的生命周期与作用域绑定,离开作用域即被销毁。

    • :变量生命周期由程序员控制,直到显式释放或程序结束。

  4. 访问速度

    • :访问速度快,因为内存连续且由硬件支持(如寄存器指针直接操作)。

    • :访问速度相对较慢,涉及指针间接寻址,且可能触发操作系统内存管理机制。

  5. 空间大小

    • :通常较小(例如几 MB),受操作系统限制,容易发生栈溢出(如递归过深)。

    • :空间较大(受限于虚拟内存),适合存储大对象或长期存在的数据。

  6. 用途示例

    • :存储函数局部变量、返回地址、参数等。

    • :存储动态数据结构(如链表、树)、大数组、需要跨函数/模块共享的数据。

  7. 线程安全性

    • :每个线程有自己的栈,天然线程安全。

    • :多个线程共享堆,需加锁等同步机制避免竞争条件。

总结对比表:

特性 栈(Stack) 堆(Heap)
分配方式 自动(系统管理) 手动(程序员管理)
生命周期 作用域结束自动释放 手动释放或程序结束
访问速度 较慢
内存大小 小(有限) 大(受限于虚拟内存)
碎片问题 可能存在
典型用途 局部变量、函数调用 动态分配、大对象、共享数据
线程安全 是(每个线程独立栈) 否(需同步机制)

相关推荐
zhouwy1138 小时前
Linux文件系统与IO编程
linux·c++
咸鱼2.09 小时前
【java入门到放弃】Dubbo
java·开发语言·dubbo
JAVA面经实录91715 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
王老师青少年编程15 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
周杰伦fans16 小时前
AutoCAD .NET 二次开发:深入理解 EntityJig 的工作原理与正确实现
开发语言·.net
叼烟扛炮16 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
样例过了就是过了17 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
Bat U18 小时前
JavaEE|多线程初阶(七)
java·开发语言
谭欣辰18 小时前
C++ 排列组合完整指南
开发语言·c++·算法