栈
栈是一个内存数组,是一个LIFO(后进先出)的数据结构。栈存储几种类型的数据:
- 某些类型变量的值;
- 程序当前的执行环境;
- 传递给方法的参数。
栈有如下几个普遍特征。 - 数据只能从栈的顶端插入和删除。
- 把数据放到栈顶称为入栈(push)。
- 从栈顶删除数据称为出栈(pop)。
堆
堆是一块内存区域,在堆里可以分配大块的内存用于存储某种类型的数据对象。与栈不同,堆里的内存能够以任意顺序存入和移除。
虽然程序可以在堆里保存数据,但并不是显示地删除它们。CLR 的自动垃圾收集器在判断出程序的代码将不会再访问某数据项时,会自动清除无主的堆对象。