加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c# – 使用析构函数的IDisposable:需要线程安全的实现吗?

发布时间:2020-12-16 01:40:30 所属栏目:百科 来源:网络整理
导读:这几乎只有我确保,我做对了: 我们有一个实现IDisposal模式的大型资源类.它应该(通过设计)以某种方式实现,这使得它可以被多次调用(即使我们尝试将其称为恰好一次).我们还实现了一个终结器,它也调用Dispose()方法 – 就像备份一样.如果手动调用,Dispose()也会
这几乎只有我确保,我做对了:

我们有一个实现IDisposal模式的大型资源类.它应该(通过设计)以某种方式实现,这使得它可以被多次调用(即使我们尝试将其称为恰好一次).我们还实现了一个终结器,它也调用Dispose()方法 – 就像备份一样.如果手动调用,Dispose()也会调用GC.SuppressFinalize(this).

有几个处理模式的例子.他们中的大多数在处理代码的末尾调用GC.SuppressFinalize(this).有人声称,最好在Dispose()方法的开头调用它,然后再进行任何清理.后者争辩说,这将确保GC不会同时调用终结器,而我们仍在清理.

题:
看来,将GC.SuppressFinalize放在一开始并没有做得更好?我们还有竞争条件,对吗?那么,我们宁愿以线程安全的方式实现Dispose()吗?

解决方法

虽然有时可能在一个看似实时的引用存在的情况下最终确定一个对象,但只有在没有其他东西可以引用该对象时才会发生这种情况. GC.SuppressFinalize(this)主动引用当前对象’this’,从而保证在GC.SuppressFinalize执行之前不会完成它.此外,对象引用存在以处置对象并且可用于Dispose方法的事实保证了在Dispose开始运行之前终结器不能排队,除非对象已经死了并且某个终结器(或者它自己的终结器),或其他一些对象的那些)复活了它.

因为在某些情况下可以安排一个对象进行最终确定并在没有意识到的情况下复活,所以保护一个部署并最终完成冗余操作可能不是一个坏主意.但是,微软的模式不是很好.可终结对象不应包含对最终化不需要的任何对象的引用.如果一个对象拥有托管和非托管资源的混合,那么非托管资源应该被移动到它们自己的类中(有效地将它们转换为托管资源),因此主要对象除了托管资源之外什么都不会.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读