中国开发网: 论坛: 程序员情感CBD: 贴子 295469
老玉米
仔细看了一次。。。其实这不是释放内存..只是cleanup,,momery并没有free。。和c++的delete语义是不一样的。。
// Implement IDisposable.
// Do not make this method virtual.
// A derived class should not be able to override this method.
public void Dispose()
{
Dispose(true);
// This object will be cleaned up by the Dispose method.
// Therefore, you should call GC.SupressFinalize to
// take this object off the finalization queue
// and prevent finalization code for this object
// from executing a second time.
GC.SuppressFinalize(this);
}

// Dispose(bool disposing) executes in two distinct scenarios.
// If disposing equals true, the method has been called directly
// or indirectly by a user's code. Managed and unmanaged resources
// can be disposed.
// If disposing equals false, the method has been called by the
// runtime from inside the finalizer and you should not reference
// other objects. Only unmanaged resources can be disposed.
private void Dispose(bool disposing)
{
// Check to see if Dispose has already been called.
if(!this.disposed)
{
// If disposing equals true, dispose all managed
// and unmanaged resources.
if(disposing)
{
// Dispose managed resources.
component.Dispose();
}

// Call the appropriate methods to clean up
// unmanaged resources here.
// If disposing is false,
// only the following code is executed.
CloseHandle(handle);
handle = IntPtr.Zero;
}
disposed = true;
}



也就是说Dispose(true)以后,这块内存还是在managed heap上被占用着。。下次垃圾收集的时候被释放,但是不执行cleanup..

所以说.net不允许手工释放对象并没有错。

相关信息:


欢迎光临本社区,您还没有登录,不能发贴子。请在 这里登录