栈和堆的底层区别

栈和堆

栈和堆

程序运行时,它的数据必须存储在内存中。一个数据项需要多大的内存、存储在什么地方、以及如何存储都因爱与该数据项的类型。
运行中的程序使用两个内存区域来进行存储数据:栈和堆。

栈是一个内存数组,是一个LIFO(Last-In Fist-Out,后进先出)的数据结构。栈存储几种类型的数据:

  1. 某些类型变量的值;
  2. 程序当前的执行环境;
  3. 传递给方法的参数;

系统管理所有的栈操作。作为程序员,你不需要显式的对他做任何事情。但是了解栈的基本功能,可能更好的了解程序在运行时正在做什么。

栈的特征

  1. 数据只能从栈的顶端插入和删除;
  2. 把数据放到栈顶成为入栈(push);
  3. 从栈顶删除数据称为出栈(pop).

入栈和出栈

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

虽然程序可以在堆里保存数据,但并不能显式地删除它们。CLR的自动GC(Garbage Collector,垃圾收集器)在判断出程序的代码将不会再访问某数据项时,自动清除无主的堆对象。我们因此可以不再操心这项使用其他编程语言时非常容易出错的工作了。图中阐明了垃圾收集过程。

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值