垃圾回收

Garbage Collection:GC

标记(marking)→压缩(compact)

类的析构函数实现Finalize方法,执行过Finalize方法后对象真正死亡。

摘自:http://www.cnblogs.com/ArmyShen/archive/2012/08/27/2657928.html

1:垃圾回收机制

CLR托管堆:

(1)第0代--预算容量256k

(2)第1代--预算容量2M

(3)第2代--预算容量10M

注:在不同的程序中,托管堆上的实际内存管理对象的容量可能不会按照预算容量大小开辟

当第0代对象充满的时候,会自动进行垃圾回收,这时第0代中未被释放的对象成为了第1代,而新创建的对象变成第0代,以此类推,当第0代再次充满的 时候会继续执行垃圾回收,未被释放的对象会被添加到第1代,随着程序的执行,第1代对象中也会产生垃圾,此时垃圾回收器并不会立即执行回收操作,而是等第 1代被充满变成第2代时被回收并整理内存。

2:Finalize析构函数被调用的条件:

(1)第0代对象充满

(2)显示调用System.GC的Collect方法

(3)Windows内存不足

(4)应用程序被关闭

(5)CLR被关闭

3:释放模式

using System;

//要实现释放模式,必须继承IDisposable
public class MyClass:IDisposable
{
    private bool disposed = false;

    private void Dispose(bool disposeing)
    {
        if (!this.disposed)
        {
            if (disposeing)
            {
                Console.WriteLine("调用引用对象的Dispose方法");
            }
            Console.WriteLine("释放类本身非托管资源");
            disposed = true;
            if (disposeing)
            {
                GC.SuppressFinalize(this);//禁止终结器的调用
            }
        }
    }

    //重写IDisposable中的Dispose方法
    public void Dispose()
    {
        Dispose(true);
    }

    //和上面的方法没区别
    public void Close()
    {
        Dispose(true);
    }

    ~MyClass()
    {
        Dispose(false);
    }
}
public class Test
{
    static void Main()
    {
        //using这个语法的使用,在实现IDisposable接口时才能使用
        using (MyClass mc = new MyClass())
        {
            Console.WriteLine("调用mc做些事情");
        }

        //MyClass mc = new MyClass();
        //try
        //{
        //    Console.WriteLine("调用mc做些事情");
        //}
        //finally
        //{
        //    mc.Dispose();
        //}
    }
}
原文地址:https://www.cnblogs.com/nygfcn1234/p/3312602.html