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

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

栈和堆的区别?

  1. 内存分配方式

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

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

  2. 内存管理

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

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

  3. 生命周期

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

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

  4. 访问速度

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

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

  5. 空间大小

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

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

  6. 用途示例

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

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

  7. 线程安全性

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

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

总结对比表:

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

相关推荐
cmpxr_21 小时前
【C】隐式类型转换
c语言·c++·算法
泛凡(Linyongui)21 小时前
PY32F002B实践之三--宠物腹背理疗仪项目功能代码分析说明
c语言·keil·32位单片机·腹背理疗仪项目实践·普苒py32
Dxy123931021621 小时前
Python使用SymSpell详解:打造极速拼写检查引擎
开发语言·python
时寒的笔记21 小时前
js7逆向案例_禁止f12打开&sojson打开
开发语言·javascript·ecmascript
大江东去浪淘尽千古风流人物21 小时前
【Basalt】nfr_mapper 中的“小 SfM/BA 后端”
c++·人工智能·计算机视觉·oracle·augmented reality
Magic--21 小时前
C++ STL中vector与list的核心区别
c++·windows·list
初願致夕霞21 小时前
Linux_线程
linux·运维·服务器·c++
2401_8920709821 小时前
【Linux C++ 后端实战】异步日志系统 AsyncLogging 完整设计与源码解析
linux·c++·高并发·异步日志
大鹏说大话21 小时前
什么是“过早优化”?
开发语言
码云数智-园园1 天前
RESTful API vs GraphQL:设计哲学、性能博弈与选型指南
开发语言