美文网首页
堆栈的区别

堆栈的区别

作者: CristianoC | 来源:发表于2020-07-14 18:37 被阅读0次

全文来自https://zhuanlan.zhihu.com/p/51612643
一般问到堆栈的区别都是问你操作系统上的,这里就不说数据结构的堆栈的区别了。

申请方式

堆是我们自己手动申请和释放的,比如c语言的malloc。而栈是程序自动的,比如在函数中生命一个局部变量a。

申请后系统的响应

栈:只要栈的剩余空间大于所申请空间,系统将为程序提供内存,否则将报异常提示栈溢出。

堆:首先应该知道操作系统有一个记录空闲内存地址的链表,当系统收到程序的申请时,会遍历该链表,寻找第一个空间大于所申请空间的堆结点,然后将该结点从空闲结点链表中删除,并将该结点的空间分配给程序,另外,对于大多数系统,会在这块内存空间中的首地址处记录本次分配的大小,这样,代码中的delete语句才能正确的释放本内存空间。另外,由于找到的堆结点的大小不一定正好等于申请的大小,系统会自动的将多余的那部分重新放入空闲链表中。

申请大小的限制

栈:在Windows下,栈是向低地址扩展的数据结构,是一块连续的内存的区域。这句话的意思是栈顶的地址和栈的最大容量是系统预先规定好的,在WINDOWS下,栈的大小是2M(也有的说是1M,总之是一个编译时就确定的常数),如果申请的空间超过栈的剩余空间时,将提示overflow。因此,能从栈获得的空间较小。

堆:堆是向高地址扩展的数据结构,是不连续的内存区域。这是由于系统是用链表来存储的空闲内存地址的,自然是不连续的,而链表的遍历方向是由低地址向高地址。堆的大小受限于计算机系统中有效的虚拟内存。由此可见,堆获得的空间比较灵活,也比较大。

申请效率的比较:

栈由系统自动分配,速度较快。但程序员是无法控制的。
堆是由new分配的内存,一般速度比较慢,而且容易产生内存碎片,不过用起来最方便.

相关文章

  • 堆栈区别

    五大内存分区在C++中,内存分成5个区,他们分别是堆、栈、自由存储区、全局/静态存储区和常量存储区。栈,就是那些由...

  • 堆栈区别

    理解不透彻,实在是无法写清楚,记录下过程吧 为了理解堆栈区别,我对比 c++,java,APP,javascipt...

  • 堆栈的区别

    stack 对象的创建 只要heap的剩余空间大于stack对象申请创建的空间, 操作系统就会为程序提供这段内存空...

  • 堆栈的区别

    全文来自https://zhuanlan.zhihu.com/p/51612643一般问到堆栈的区别都是问你操作系...

  • 堆、栈

    栈, 也叫堆栈 堆和栈的区别: 堆栈空间分配区别:1、栈(操作系统):由操作系统自动分配释放 ,存放函数的参数值,...

  • 什么是堆栈,以及堆栈的区别

    首先,讨论的堆和栈指的是内存中的“堆区”和“栈区”,OC语言是C语言的超集,所以先了解C语言的内存模型的内存管理会...

  • JAVA堆栈的区别

    1 JVM栈 (Java Virtual Machine Stacks) 在介绍JVM栈之前,我先了解一下 栈帧 ...

  • ios 堆栈区别

  • 堆栈

    #什么是“堆”,"栈","堆栈","队列",它们的区别 如果你学过数据结构,就一定会遇到“堆”,"栈","堆栈",...

  • 堆栈概念及区别

    在计算机领域,堆栈是一个不容忽视的概念,堆栈是两种数据结构。堆栈都是一种数据项按序排列的数据结构,只能在一端(称为...

网友评论

      本文标题:堆栈的区别

      本文链接:https://www.haomeiwen.com/subject/mbifhktx.html