C++——内存中的栈区和堆区

四、内存中的栈区和堆区 (Stack and Heap)

概念:

  • 栈区 (Stack): 就像一个后进先出的箱子。

  • 堆区 (Heap): 就像一个巨大的、可以自由分配和回收的空地。程序员可以使用 newdelete 手动地在这片区域申请和释放内存。 堆区的大小相对较大,但需要程序员自己管理。

示例代码:

cpp 复制代码
#include <iostream>

int* createOnHeap() {
  int* num = new int(100); // 在堆区分配内存
  return num;
}

void functionOnStack() {
  int localVar = 50; // 在栈区分配内存
  std::cout << "栈区变量 localVar 的地址: " << &localVar << std::endl;
}

int main() {
  // 栈区变量
  int a = 10;
  std::cout << "栈区变量 a 的地址: " << &a << std::endl;

  // 堆区变量
  int* b = new int;
  *b = 20;
  std::cout << "堆区变量 b 的地址: " << b << std::endl;

  functionOnStack();

  int* heapVar = createOnHeap();
  std::cout << "堆区变量 heapVar 的地址: " << heapVar << std::endl;
  std::cout << "堆区变量 heapVar 指向的值: " << *heapVar << std::endl;
  delete heapVar;
  heapVar = nullptr;

  return 0;
}

讲解要点:

  • 栈区和堆区的区别:
特征 栈区 (Stack) 堆区 (Heap)
分配和释放 编译器自动分配和释放 程序员手动分配和释放 (new/delete)
存储内容 局部变量、函数参数、函数调用信息 动态分配的内存
大小限制 有限,由编译器或操作系统预先设定 相对较大,受系统可用内存限制
分配速度 相对较慢
管理方式 自动管理 手动管理
  • 栈区和堆区的内存分配方式:

    • 栈区: 内存分配和释放就像叠盘子一样,后进先出。
    • 堆区: 内存分配和释放更加灵活,可以在任意时刻申请和释放任意大小的内存块。操作系统维护着一个空闲内存列表,当 new 请求内存时,系统会找到合适的空闲块分配出去。
  • 堆是内存区域,指针是访问内存的工具

延申问题:堆是指针吗 堆(Heap)不是指针,但堆内存的访问必须通过指针来实现。

相关推荐
yuhaiqiang1 小时前
为什么我建议你不要只问一个AI?🤫偷偷学会“群发”,答案准到离谱!
人工智能·后端·ai编程
双向332 小时前
AR 眼镜拯救社恐:我用 Kotlin 写了个拜年提词器
后端
吾日三省Java2 小时前
Spring Cloud架构下的日志追踪:传统MDC vs 王炸SkyWalking
java·后端·架构
想打游戏的程序猿2 小时前
服务端用AI写前端:隐患、困境与思考
后端
前端拿破轮2 小时前
从0到1搭建个人网站(三):用 Cloudflare R2 + PicGo 搭建高速图床
前端·后端·面试
树獭叔叔2 小时前
深度拆解 DiT:扩散模型与 Transformer 的巅峰结合
后端·aigc·openai
ZhengEnCi2 小时前
08c. 检索算法与策略-混合检索
后端·python·算法
用户7344028193423 小时前
Java 8 Stream 的终极技巧——Collectors 操作
后端
树獭叔叔3 小时前
深度拆解 VAE:生成式 AI 的潜空间大门
后端·aigc·openai
任沫3 小时前
字符串
数据结构·后端