堆和栈的区别

做了这么长时间的开发、一直弄不清楚堆和栈的区别、其实也不算弄不清吧、只是每次都区分不了、

1.操作系统的堆和栈

 

  堆-(操作系统):先进后出的序列、由程序员分配内存并释放、若程序员不释放、则程序结束时候由系统OS回收、

          堆使用的是二级缓存、生命周期由虚拟机的垃圾回收算法来决定(并不是一旦成为孤儿对象就能被回收)、所以调用这些对象的速度要相对来得低一些

 

  栈-(操作系统):先进先出的序列、由编译器自动分配和释放、用来存放函数的参数、和局部变量的值、

          栈使用的是一级缓存、调用时处于存储空间中、调用完毕立即释放、

2数据结构中的堆和栈

 

  堆-(数据结构):堆可以被看成是一棵树,如:堆排序
 
  栈-(数据结构_:一种先进后出的数据结构

转载于:https://www.cnblogs.com/keryang/p/4249408.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值