堆和栈的区别是啥?

堆和栈的区别是啥?,第1张

堆和栈的区别:

一.堆栈空间分配区别:

1.栈( *** 作系统):由 *** 作系统自动分配释放 ,存放函数的参数值,局部变量的值等。其 *** 作方式类似于数据结构中的栈;

2.堆( *** 作系统): 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收,分配方式倒是类似于链表。

二.堆栈缓存方式区别:

1.栈使用的是一级缓存, 他们通常都是被调用时处于存储空间中,调用完毕立即释放;

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

三.堆栈数据结构区别:

堆(数据结构):堆可以被看成是一棵树,如:堆排序;

栈(数据结构):一种先进后出的数据结构。

扩展资料:

堆支持以下的基本:

1.build:建立一个空堆;

2.insert:向堆中插入一个新元素

3.update:将新元素提升使其符合堆的性质;

4.get:获取当前堆顶元素的值;

5.delete:删除堆顶元素;

6.heapify:使删除堆顶元素的堆再次成为堆。

某些堆实现还支持其他的一些 *** 作,如斐波那契堆支持检查一个堆中是否存在某个元素。

栈的基本算法

1.进栈(PUSH)算法

①若TOP≥n时,则给出溢出信息,作出错处理(进栈前首先检查栈是否已满,满则溢出;不满则作②);

②置TOP=TOP+1(栈指针加1,指向进栈地址);

③S(TOP)=X,结束(X为新进栈的元素);

2.退栈(POP)算法

①若TOP≤0,则给出下溢信息,作出错处理(退栈前先检查是否已为空栈, 空则下溢;不空则作②);

②X=S(TOP),(退栈后的元素赋给X):

③TOP=TOP-1,结束(栈指针减1,指向栈顶)。

参考资料:百度百科:堆

百度百科:栈

堆栈与堆区别为:空间不同、地址方向不同、释放不同。

一、空间不同

1、堆栈:堆栈是自动分配变量,以及函数调用的时候所使用的一些空间。

2、堆:堆是是由malloc之类函数分配的空间所在地。

二、地址方向不同

1、堆栈:堆栈的地址方向是由高向低减少性扩展,有总长度大小限制。

2、堆:堆的地址方向是由低向高增长性扩展,没有总长度大小限制。

三、释放不同

1、堆栈:堆栈由编译器自动释放,存放函数的参数值,局部变量的值等。

2、堆:堆由程序员人工进行释放, 若程序员不释放,程序结束时可能由OS回收 。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/8326443.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-15
下一篇 2023-04-15

发表评论

登录后才能评论

评论列表(0条)

保存