美文网首页
栈和堆是什么意思

栈和堆是什么意思

作者: 目标肢解 | 来源:发表于2016-06-11 23:35 被阅读0次

堆(Heap)栈(Stack)

堆:一般由程序员分配释放, 若程序员不释放,程序结束时可能由 OS 回收 。注意它与数据结构中的堆是两回事,分配方式是类似于链表。可能用到的关键字如下:new、malloc、delete、free等等。

栈:由编译器 (Compiler) 自动分配释放,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。

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

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

相关文章

  • 栈和堆是什么意思

    堆(Heap)栈(Stack) 堆:一般由程序员分配释放, 若程序员不释放,程序结束时可能由 OS 回收 。注意它...

  • 堆和栈, 他们是什么?

    堆和栈, 他们是什么? 文章地址 堆 堆包含一个链表 来维护已用和空闲的内存块. 在堆上新分配内存是从空闲的内存块...

  • 2018-01-03三题

    1.堆内存和栈内存的区别是什么? 线程的堆内存空间是共享的,栈内存空间才是独立的(堆共享,栈独立)。 2.wait...

  • 10.11java中的堆和栈

    java高级-堆和栈 java堆 /栈 栈内存 / 堆内存的区别 1. java堆 /栈 2. 栈内存 / 堆内存的区别

  • 堆和栈

    一 java 堆内存和栈内存 java把内存分为两种:一种是堆内存,一种是栈内存 堆: 堆内存主要存储实例化对象,...

  • 堆和栈

    栈区(stack)由编译器自动分配释放 ,存放方法(函数)的参数值, 局部变量的值等,栈是向低地址扩展的数据结构,...

  • 堆和栈

    堆和栈在内存地址空间中的位置是不一样的,堆向上增长,而栈向下增长;其次,他们的功能也不一样,堆中的空间程序员可以自...

  • 堆和栈

    基本要点 基本数据类型、局部变量都是存放在栈内存中的,用完就消失了。new创建的实例化对象及数组,是放在堆内存中的...

  • 堆和栈

     按管理方式看:oc对象存放于堆里面(堆内存需要程序员手动回收) 非oc对象一般放在栈里面(栈内存会被系统自...

  • 堆和栈

    一个由C/C++编译的程序占用的内存分为以下几个部分1、栈区(stack)— 由编译器自动分配释放 ,存放...

网友评论

      本文标题:栈和堆是什么意思

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