C# 中的栈和堆
程序员文章站
2023-10-28 19:30:46
程序运行时,它的数据必须存储在内存中。一个数据项需要多大的内存、存储在内存中的什么位置、以及如何存储都依赖于该数据项的类型。 运行中的程序使用两个内存区域来存储数据:栈和堆。 栈 栈是一个内存数组,是一个 LIFO (Last In First Out,后进先出)的数据结构。栈存储几种类型的数据: ......
程序运行时,它的数据必须存储在内存中。一个数据项需要多大的内存、存储在内存中的什么位置、以及如何存储都依赖于该数据项的类型。
运行中的程序使用两个内存区域来存储数据:栈和堆。
栈
栈是一个内存数组,是一个 lifo (last-in first-out,后进先出)的数据结构。栈存储几种类型的数据:
- 某些类型变量的值
- 程序当前的执行环境
- 传递给方法的参数
系统管理所有的栈操作。作为程序员,你不需要显式地对它做任何事情。但了解栈的基本功能可以更好地了解程序在运行时正在做什么。
提示: 栈也经常被称为堆栈,而堆依然称为堆,所以堆栈这个概念并不包含堆,大家要注意区分。
栈的特征
栈有如下几个普遍特征:
- 数据只能从栈的顶端插人和删除
- 把数据放到栈顶称为入栈(push)
- 从栈顶删除数据称为出栈(pop)
堆
堆是一块内存区域,在堆里可以分配大块的内存用于存储某类型的数据对象。与栈不同,堆里的内存能够以任意顺序存人和移除。下图展示了一个在堆里放了 4 项数据的程序。
虽然程序可以在堆里保存数据,但并不能显式地删除它们。clr 的自动 gc(garbage collector,垃圾收集器)在判断出程序的代码将不会再访问某数据项时,自动清除无主的堆对象。我们因此可以不再操心这项使用 c 编程语言时非常容易出错的工作了。下图阐明了垃圾收集过程。
总结
本篇介绍了栈和堆最最最基本的概念,主要是为下一篇(地址:)介绍值类型和引用类型打基础。
上一篇: 鸭血常见,可你对它有所了解吗
下一篇: 麻醉
推荐阅读