目录 完整示例 为什么要实现Foo析构函数 Dispose方法中为什么要调用GC.SuppressFinalize Reference Why using finalizers is a bad idea 当在一个类中使用了另外一个实现了 IDisposable 的类作为一个成员属性
目录
- 完整示例
- 为什么要实现Foo析构函数
- Dispose方法中为什么要调用GC.SuppressFinalize
Reference
Why using finalizers is a bad idea
当在一个类中使用了另外一个实现了IDisposable
的类作为一个成员属性时, 此时这个类就有必要也去实现IDisposable接口, 以确保在合适的实际释放非托管资源, 到底该如何正确的实现这个接口呢? 当然这只是需要实现IDisposable接口其中一种情况
完整示例
示例的Foo
类中包含了一个Stream
类型的_stream
成员, 因此需要为Foo类实现IDisposable模式
public class Foo : IDisposable { private bool _disposed; private readonly Stream? _stream; public Foo() { _stream = File.Create("1.txt", 2048); } ~Foo() { CleanupUnmanagedResources(); } private void CleanupUnmanagedResources() { if (_disposed) return; // 释放非托管资源 _stream?.Dispose(); _disposed = true; } public void Dispose() { CleanupUnmanagedResources(); GC.SuppressFinalize(this); } }
为什么要实现Foo析构函数
因为人性的弱点(