标签:
对于一些新人可能会不理解栈和堆是什么,在这里我简单介绍一下:
程序运行时,它的数据必须存储在内存中。一个数据项需要多大的内存、存储在什么地方、以及如何存储都依赖与该数据项的类型。
运行中的程序使用两个内存区域来存储数据:栈和堆。
首先,什么是“栈”?
栈是一个内存数组,是一个LIFO(last-in first-out,后进先出)的数据结构。栈存储几种类型的数据:
栈的特征:
栈有如下几个普遍特征:
什么是“堆”?
堆是一块内存区域,在堆里可以分配大块的内存用于存储某类型的数据。与栈不同,堆里的内存可以任意顺序存入和移除。
虽然程序可以在堆里保存数据,但并不能显示地删除它们。CLR的自动GC(Garbage Collector,垃圾收集器)在判断出程序的
代码将不会再访问某数据项是,自动清除无助的堆对象。我们因此可以不再操心这项使用其他编程语言时非常容易出错的工作了。
堆栈空间分配:
总之:堆,队列优先,先进先出,栈,先进后出,而且栈的存取速度比堆快。
标签:
原文地址:http://www.cnblogs.com/wcf6676/p/4606590.html