【转】对于一些新人可能会不理解栈和堆是什么,在这里我简单介绍一下:
程序运行时,它的数据必须存储在内存中。一个数据项需要多大的内存、存储在什么地方、以及如何存储都依赖与该数据项的类型。
运行中的程序使用两个内存区域来存储数据:栈和堆。
首先,什么是“栈”?
栈是一个内存数组,是一个LIFO(last-in first-out,后进先出)的数据结构。栈存储几种类型的数据:
某些类型变量的值
程序当前的执行环境
传递给方法的参数
栈的特征:
栈有如下几个普遍特征:
数据只能从栈的顶端插入和删除
把数据放到栈顶称为入栈(push)
从栈顶删除数据称为出栈(pop)
什么是“堆”?
堆是一块内存区域,在堆里可以分配大块的内存用于存储某类型的数据。与栈不同,堆里的内存可以任意顺序存入和移除。
虽然程序可以在堆里保存数据,但并不能显示地删除它们。CLR的自动GC(Garbage Collector,垃圾收集器)在判断出程序的
代码将不会再访问某数据项是,自动清除无助的堆对象。我们因此可以不再操心这项使用其他编程语言时非常容易出错的工作了。
堆栈空间分配:
栈(操作系统):由操作系统自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。
堆(操作系统): 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收,分配方式倒是类似于链表。
总之:堆,队列优先,先进先出,栈,先进后出,而且栈的存取速度比堆快。
|
|