博客
关于我
堆和栈的区别
阅读量:405 次
发布时间:2019-03-06

本文共 1234 字,大约阅读时间需要 4 分钟。

一、程序内存分配概述

一个由C/C++编译的程序占用的内存主要包括以下几个部分:

  • 栈区(Stack)

    栈区的内存是由编译器自动分配和释放的,用于存放函数调用的参数值以及局部变量的值。其工作方式类似于数据结构中的栈,先进后出。

  • 堆区(Heap)

    堆区的内存分配和释放由程序员控制。如果程序未释放内存,程序结束时可能由操作系统回收。需要注意的是,这里的堆区与数据结构中的堆不同,虽然分配方式类似于链表。

  • 全局区(Static区)

    全局变量和静态变量的存储放在这里。初始化的全局变量与静态变量存放在一块区域,未初始化的全局变量和静态变量则存放在相邻的另一块区域。程序结束后,这些内存由系统释放。

  • 文字常量区

    存放常量字符串等内容,程序结束后由系统释放。

  • 程序代码区

    存储函数体的二进制代码。

  • 二、例子程序分析

    以下是一个详细的示例程序,用于说明上述内存分配方式:

    // main.cpp

    int a = 0; // 全局未初始化区
    char *p1; // 全局未初始化区
    main() {
    int b; // 栈区
    char s[] = "abc"; // 栈区
    char *p2; // 栈区
    char *p3 = "123456"; // 栈区
    static int c = 0; // 全局静态区

    p1 = (char *)malloc(10); // 堆区分配  p2 = new char[20];       // 堆区分配  strcpy(p1, "123456"); // 常量字符串优化到常量区

    }

    三、堆和栈的区别与特点

    3.1 申请方式

    栈:由系统自动分配,例如声明局部变量时,系统会自动在栈中分配内存。

    堆:需要程序员手动申请,使用malloc或new运算符。

    3.2 申请后系统响应

    栈:系统会检查栈的剩余空间是否足够,若足够则分配,否则报错。

    堆:系统会遍历空闲内存链表,找到合适的块进行分配,并记录分配的大小。

    3.3 申请大小限制

    栈:在Windows系统中,栈的大小通常为2M(具体数值可能因系统而异)。申请超过栈剩余空间会导致溢出错误。

    堆:堆的大小主要由系统的有效虚拟内存决定,申请较大空间比较灵活。

    3.4 申请效率对比

    栈分配速度快,但程序员无法控制分配方式。

    堆分配较慢,但提供了更大的灵活性和控制权。

    3.5 堆和栈的存取效率对比

    以数组和指针存取为例:
    char s1[] = "aaaaaaaaaaaaaaa"; // 运行时赋值,存取速度较慢
    char *s2 = "bbbbbbbbbbbbbbbbb"; // 编译时确定,存取速度较快

    3.6 堆和栈的内存管理特点

    堆区通常在首地址处记录分配大小,便于释放。栈的内存管理较为简单,主要用于函数调用和变量存储。

    四、小结

    堆和栈的主要区别在于申请方式和管理方式。栈适用于快速且控制有限的内存需求,而堆提供了更大的灵活性和空间控制。选择哪种方式取决于具体需求和性能考量。

    转载地址:http://dubkz.baihongyu.com/

    你可能感兴趣的文章
    Nginx的可视化神器nginx-gui的下载配置和使用
    查看>>
    Nginx的是什么?干什么用的?
    查看>>
    Nginx访问控制_登陆权限的控制(http_auth_basic_module)
    查看>>
    nginx负载均衡器处理session共享的几种方法(转)
    查看>>
    nginx负载均衡的5种策略(转载)
    查看>>
    nginx负载均衡的五种算法
    查看>>
    Nginx运维与实战(二)-Https配置
    查看>>
    Nginx配置ssl实现https
    查看>>
    Nginx配置TCP代理指南
    查看>>
    Nginx配置——不记录指定文件类型日志
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    Nginx配置参数中文说明
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    NHibernate学习[1]
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>