ZERO_BEYOND

博客园 首页 联系 订阅 管理

栈和堆

栈(stack): 数据只能从栈的顶端插⼊和删除 把数据放⼊栈顶称为⼊栈(push) 从栈顶删除数据称为出栈(pop)

栈是自上向下进行填充,即由高内存地址指向低内存地址,并且内存分配是连续的,C#中所有的值类型和引用类型的引用都分配在栈上, 栈根据后进先出的原则,依次对分配和释放内存对象。

堆(heap):堆是⼀块内存区域,与栈不同,堆⾥的内存能够以任意顺序存⼊和移除

堆是从下往上分配,所以已用的空间在自由空间下面,C#中所有引用类型的对象分配在托管堆上,托管堆在内存上是连续分配的, 并且内存对象的释放受垃圾收集机制的管理,效率相对于栈来说要低的多。

posted on 2023-11-13 09:08  ZERO_BEYOND  阅读(11)  评论(0编辑  收藏  举报