我的类包含一个来自 Interop 的对象,并在其上调用一个方法,导致它分配东西。它还公开了一个释放这些东西的方法,所以我希望我应该在 Dispose() 中调用它:
class MyClass : IDisposable
{
private DllName.ComClassName comInstance;
void SomeMethod()
{
comInstance = new DllName.ComClassName();
comInstance.AllocStuff();
}
public void Dispose()
{
comInstance.FreeThatStuff();
}
}
现在,我应该扩展所有内容以遵循 Dispose 模式。我没有其他一次性或非托管资源要释放,因此假设 comInstance 是托管的(这不是 Interop 所做的,将非托管包装到托管中吗?),我认为该模式分解为:
public void Dispose()
{
if (comInstance != null)
{
comInstance.FreeStuff();
comInstance = null;
}
}
除非我在 MyClass 的实例上显式调用 Dispose(),否则哪些泄漏会导致 Dispose 模式存在缺陷?那么这是否意味着 comInstance 必须是非托管的,并且该模式分解为:
public void Dispose()
{
DisposeComInstance();
GC.SuppressFinalize(this);
}
~MyClass()
{
DisposeComInstance();
}
private void DisposeComInstance()
{
if (comInstance != null)
{
comInstance.FreeStuff();
comInstance = null;
}
}
编辑:
- 为了避免让我的班级被完整的模式弄得乱七八糟,我可以密封我的班级吗?
- 我怎么知道 ComClassName(通常是任何类)是非托管的?