栈和堆
程序运行时,它的数据必须存储在内存中。一个数据项需要多大的内存、存储在什么地方、以及如何存储都因爱与该数据项的类型。
运行中的程序使用两个内存区域来进行存储数据:栈和堆。
栈
栈是一个内存数组,是一个LIFO(Last-In Fist-Out,后进先出)的数据结构。栈存储几种类型的数据:
- 某些类型变量的值;
- 程序当前的执行环境;
- 传递给方法的参数;
系统管理所有的栈操作。作为程序员,你不需要显式的对他做任何事情。但是了解栈的基本功能,可能更好的了解程序在运行时正在做什么。
栈的特征
- 数据只能从栈的顶端插入和删除;
- 把数据放到栈顶成为入栈(push);
- 从栈顶删除数据称为出栈(pop).
堆
堆是一块内存区域,在堆里可以分配大块的内存用于存储某类型的数据对象。与栈不同,堆里的内存能够以任意顺序存入和移除。
虽然程序可以在堆里保存数据,但并不能显式地删除它们。CLR的自动GC(Garbage Collector,垃圾收集器)在判断出程序的代码将不会再访问某数据项时,自动清除无主的堆对象。我们因此可以不再操心这项使用其他编程语言时非常容易出错的工作了。图中阐明了垃圾收集过程。