首页 > 代码库 > 堆和栈的区别
堆和栈的区别
做了这么长时间的开发、一直弄不清楚堆和栈的区别、其实也不算弄不清吧、只是每次都区分不了、
1.操作系统的堆和栈
堆-(操作系统):先进后出的序列、由程序员分配内存并释放、若程序员不释放、则程序结束时候由系统OS回收、
堆使用的是二级缓存、生命周期由虚拟机的垃圾回收算法来决定(并不是一旦成为孤儿对象就能被回收)、所以调用这些对象的速度要相对来得低一些
栈-(操作系统):先进先出的序列、由编译器自动分配和释放、用来存放函数的参数、和局部变量的值、
栈使用的是一级缓存、调用时处于存储空间中、调用完毕立即释放、
2数据结构中的堆和栈
堆-(数据结构):堆可以被看成是一棵树,如:堆排序
栈-(数据结构_:一种先进后出的数据结构
堆和栈的区别
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。