zoukankan      html  css  js  c++  java
  • C#垃圾回收机制

    转自: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();
            //}
        }
    }
    复制代码
  • 相关阅读:
    7-4 找出不是两个数组共有的元素(20 分)
    7-2 删除重复字符(20 分)
    7-1 兔子繁衍问题(15 分)
    1018 Public Bike Management (30分) (迪杰斯特拉+dfs)
    PAT 1014 Waiting in Line (30分) 一个简单的思路
    1010 Radix (25分)
    试题编号: 201809-4 试题名称: 再卖菜 记忆化搜索
    试题编号: 201903-3 试题名称: 损坏的RAID5
    CCF 试题编号: 201909-4 试题名称: 推荐系统
    洛谷P3809 后缀数组模板
  • 原文地址:https://www.cnblogs.com/cugwx/p/4060146.html
Copyright © 2011-2022 走看看