栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

什么时候应该使用GC.SuppressFinalize()?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

什么时候应该使用GC.SuppressFinalize()?

SuppressFinalize应该仅由具有终结器的类调用。它通知垃圾收集器(GC)

this
对象已被完全清除。

拥有终结器的建议IDisposable模式为:

public class MyClass : IDisposable{    private bool disposed = false;    protected virtual void Dispose(bool disposing)    {        if (!disposed)        { if (disposing) {     // called via myClass.Dispose().      // OK to use any private object references } // Release unmanaged resources. // Set large fields to null.      disposed = true;        }    }    public void Dispose() // Implement IDisposable    {        Dispose(true);        GC.SuppressFinalize(this);    }    ~MyClass() // the finalizer    {        Dispose(false);    }}

通常,CLR在创建终结器时保留带有终结器的选项卡(使它们的创建成本更高)。SuppressFinalize告诉GC,该对象已正确清理,不需要进入终结器队列。它看起来像一个C
++析构函数,但功能却不一样。

SuppressFinalize优化并非微不足道,因为您的对象可以在终结器队列上等待很长时间。不要介意在其他对象上调用SuppressFinalize。那是一个严重的缺陷,等待发生。

设计准则通知我们,如果您的对象实现IDisposable,则不需要终结器,但如果您具有终结器,则应实现IDisposable,以便对类进行确定性清除。

大多数时候,您应该能够摆脱IDisposable的清理资源。仅当您的对象保留非托管资源时,才需要终结器,并且需要确保这些资源被清除。

注意:有时,编码人员会添加一个终结器来调试其自己的IDisposable类的构建,以测试代码是否已正确处理其IDisposable对象。

    public void Dispose() // Implement IDisposable    {        Dispose(true);    #if DEBUG        GC.SuppressFinalize(this);    #endif    }    #if DEBUG    ~MyClass() // the finalizer    {        Dispose(false);    }    #endif


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/390449.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号