堆(heap)和栈(stack)的区别

堆(heap)和栈(stack)的区别

栈:

  1. 执行效率较高
  2. 申请和分配系统自动完成
  3. 空间较小—不易存放大量数据,因为可能会栈溢出
  4. 有名空间–可以通过名称访问
  5. 在函数调用结束时会释放变量空间

堆:

  1. 执行效率较低
  2. 申请和分配有程序员自己完成
  3. 空间较大—可以保存较大量的数据
  4. 无名空间----只能通过指针访问
  5. 程序结束释放,或者由程序员调用free()释放

1.栈内存存储的是局部变量而堆内存存储的是实体;
2.栈内存的更新速度要快于堆内存,因为局部变量的生命周期很短;
3.栈内存存放的变量生命周期一旦结束就会被释放,而堆内存存放的实体会被垃圾回收机制不定时的回收。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

邢一

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值