堆和栈的区别

本文深入解析程序运行时内存分配的五大分区,着重对比堆与栈的分配方式、系统响应、大小限制与申请效率。了解两者在程序开发中的应用与区别,助您高效管理内存资源。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

答:一般程序常分为以下5个分区:

(1)堆区:由程序员自己分配和释放(new/delete || malloc/free),若程序员不释放,程序结束时可能由操作系统OS回收

(2)栈区:由编译器分配和释放,通常存储由函数参数值、局部变量值及函数调用地址等

(3)全局区:一般存储全局变量和静态变量,其中初始化的全局变量和静态变量放在一块,未初始化的全局变量和静态变量存放在相邻的另一区,程序结束时由OS分配

(4)文字常量区:一般存储常量字符串,程序结束时由OS分配

(5)程序代码区:存储函数体的二进制代码(注:程序源代码占用内存空间,如内联函数)

以上是关于程序运行时,内存的分配情况,下面主要介绍堆和栈的区别:

(1)内存分配方面:堆是由程序员分配和释放;栈是由编译器自动分配和释放

(2)系统响应方面:
堆:操作系统有一个记录空闲内存地址的链表,当系统收到程序的申请时,会遍历该链表,寻找第一个空间大于所申请空间的堆结点,然后将该结点从空闲结点链表中删除, 并将该结点的空间分配给程序,另外,对于大多数系统,会在这块内存空间中的首地址处记录本次分配的大小,这样代码中的delete语句才能正确的释放本内存空间。另 外由于找到的堆结点的大小不一定正好等于申请的大小,系统会自动的将多余的那部分重新放入空闲链表中。
栈:只要栈的剩余空间大于所申请空间,系统将为程序提供内存,否则将报异常提示栈溢出。

(3)大小限制方面:

堆:是向高地址扩展的数据结构,是不连续的内存区域,从堆中获取的空间一般比较大(堆的大小受限于计算机系统中有效的虚拟内存)

栈:是向低地址扩展的数据结构,是一块连续的内存的区域,从栈中获取的空间一般比较小(栈的大小受限于编译器)

(4)申请效率方面:

堆:一般由New分配,速度比较慢,而且容易产生碎片

栈:一般由编译器自动分配,速度比较快



参考:http://blog.youkuaiyun.com/hairetz/article/details/4141043

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值