对堆heap和栈stack的理解

本文通过生动的比喻介绍了堆和栈的基本概念,进一步从申请方式、大小限制等方面详细解析两者之间的区别。

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

【堆heap】由编译器自动分配释放,如int a;系统在栈中自动为a开辟存储空间。

后进先出,压栈方向是向低地址

打个比方,一条绳子下掉了一块铁块,然后放到水中,绳子的上端与水平面平齐且铁块最初也在水平面,当我们添加铁块的时候,重叠的铁块就会慢慢往下沉(绳子可伸缩),这个动作就相当于:压栈。栈底在水平面,栈顶就是铁块的位置,当我们要从水里把铁块取出的时候,就往上拉,这样后面放进去的铁块就最先露出水平面,也就是后进先出的道理。

【栈stack】由程序员分配释放,如malloc

先进先出(队列)

堆可以这样理解,就相当于没有绳子挂着的铁块,先进的就沉到水底了,出口也在水底。

 

上述只是一个感性的理解,下面从理论的角度分析两者的区别

1、申请方式

2、申请大小限制

3、申请后系统响应

。。。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值