1.群里讨论中扯出来点,先记录下来关于GC的一些认识
建立一个测试项目。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
namespace GC_Test
{
class Program
{
static void Main(string[] args)
{
//托管代码.被CLR管理的代码
//非托管代码.不被CLR管理的代码
//应用程序域:
//分配在栈空间的变量 一旦执行完其所在的作用域 这个变量就会被CLR立即回收.
//分配在堆里面的对象 当没有任何变量引用它的时候,这个对象就被标记为"垃圾对象",等待垃圾回收器回收.
//GC会定时的清理堆空间中的垃圾对象.
//GC清理垃圾对象的频率 程序员无法决定 CLR会自动控制.
//当1个对象被标记为"垃圾"的时候,这个对象不一定会被立即回收.
// GC.GetGeneration(p); //得到指定的对象所在的代
// GC.MaxGeneration;返回代数.
// GC.Collect(); 立即让垃圾回收器对所有的代进行回收.
// GC.Collect(int gen); 对指定的代立即进行垃圾回收.
Person p = new Person();
Console.WriteLine("p对象所在的代:"+GC.GetGeneration(p));
GC.Collect();

本文探讨了.NET中的垃圾回收机制,重点介绍了GC如何自动清理不再被引用的对象,并将其分为三代进行管理。当对象手动设置为null时,GC会在下一次清理时回收该对象,并调用其析构函数。作者通过测试项目和运行结果展示了GC的工作过程,并邀请读者加入.NET技术交流群进行进一步讨论。
最低0.47元/天 解锁文章
1034

被折叠的 条评论
为什么被折叠?



