你的位置:首页 > 软件开发 > ASP.net > 浅谈“栈和堆”

浅谈“栈和堆”

发布时间:2015-06-29 11:00:20
对于一些新人可能会不理解栈和堆是什么,在这里我简单介绍一下:程序运行时,它的数据必须存储在内存中。一个数据项需要多大的内存、存储在什么地方、以及如何存储都依赖与该数据项的类型。运行中的程序使用两个内存区域来存储数据:栈和堆。 首先,什么是“栈&rd ...

对于一些新人可能会不理解栈和堆是什么,在这里我简单介绍一下:

程序运行时,它的数据必须存储在内存中。一个数据项需要多大的内存、存储在什么地方、以及如何存储都依赖与该数据项的类型。

运行中的程序使用两个内存区域来存储数据:栈和堆。

 

首先,什么是“栈”?

栈是一个内存数组,是一个LIFO(last-in  first-out,后进先出)的数据结构。栈存储几种类型的数据:

  • 某些类型变量的值
  • 程序当前的执行环境
  • 传递给方法的参数

栈的特征:

栈有如下几个普遍特征:

  • 数据只能从栈的顶端插入和删除
  • 把数据放到栈顶称为入栈(push)
  • 从栈顶删除数据称为出栈(pop)

什么是“堆”?

堆是一块内存区域,在堆里可以分配大块的内存用于存储某类型的数据。与栈不同,堆里的内存可以任意顺序存入和移除。

虽然程序可以在堆里保存数据,但并不能显示地删除它们。CLR的自动GC(Garbage Collector,垃圾收集器)在判断出程序的

代码将不会再访问某数据项是,自动清除无助的堆对象。我们因此可以不再操心这项使用其他编程语言时非常容易出错的工作了。

 

堆栈空间分配:

栈(操作系统):由操作系统自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。

原标题:浅谈“栈和堆”

关键词:

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。

可能感兴趣文章

我的浏览记录