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)不是指针,但堆内存的访问必须通过指针来实现。

相关推荐
IT_陈寒15 小时前
为什么我的Vite热更新老是重新加载整个页面?
前端·人工智能·后端
还在忙碌的吴小二15 小时前
Harness 最佳实践:Java Spring Boot 项目落地 OpenSpec + Claude Code
java·开发语言·spring boot·后端·spring
三分恶15 小时前
支付江湖路—第一章:支付溯源——从贝壳到比特
后端
武子康16 小时前
大数据-264 实时数仓-MySQL Binlog配置详解:从原理到实践|数据恢复与主从复制实战
大数据·hadoop·后端
倾颜16 小时前
接入 MCP,不一定要先平台化:一次 AI Runtime 的实战取舍
前端·后端·mcp
wechat_Neal16 小时前
Golang的车载应用场景
开发语言·后端·golang
Moment16 小时前
AI全栈入门指南:一文搞清楚NestJs 中的 Controller 和路由
前端·javascript·后端
GetcharZp16 小时前
告别繁琐配置!这款 Go 写的 Web 服务器,凭什么让 Nginx 都不香了?
后端
IT_陈寒16 小时前
Python的asyncio把我整不会了,原来问题出在这儿
前端·人工智能·后端
武子康16 小时前
大数据-265 实时数仓-Canal MySQL Binlog配置详解:从原理到实践|数据恢复与主从复制实战
大数据·hadoop·后端