我在串行端口类上有适配器模式(包装器)。我应该实现IDisposable模式并在其中调用_wrappedSerialPort.Dispose()吗?有我的课,对吗?
public class SerialPortAdapter : ISerialPortAdapter
{
private bool _disposed;
public event SerialDataReceivedEventHandler DataReceived;
private readonly SerialPort _wrappedSerialPort;
public SerialPort WrappedSerialPort
{
get { return _wrappedSerialPort; }
}
public string PortName
{
get { return _wrappedSerialPort.PortName; }
set { _wrappedSerialPort.PortName = value; }
}
public BaudRate BaudRate
{
get { return (BaudRate)Enum.ToObject(typeof(BaudRate), _wrappedSerialPort.BaudRate); }
set { _wrappedSerialPort.BaudRate = (int)value; }
}
public bool IsOpen
{
get { return WrappedSerialPort.IsOpen; }
}
public SerialPortAdapter(SerialPort serialPort)
{
_wrappedSerialPort = serialPort;
_wrappedSerialPort.DataReceived += SerialPortDataReceived;
}
public void OpenPort()
{
if (!_disposed)
{
if (!WrappedSerialPort.IsOpen)
{
WrappedSerialPort.Open();
}
}
}
public void ClosePort()
{
if (!_disposed)
{
if (WrappedSerialPort.IsOpen)
{
WrappedSerialPort.Close();
}
}
}
public void WriteLine(string request)
{
...
}
public void Write(byte[] request)
{
....
}
public byte[] Read()
{
....
}
public string ReadLine()
{
...
}
private void SerialPortDataReceived(object sender, SerialDataReceivedEventArgs e)
{
if (DataReceived != null)
{
DataReceived(this, e);
}
}
#region IDisposable Members
public virtual void Dispose()
{
Dispose(true);
GC.SuppressFinalize(this);
}
private void Dispose(bool disposing)
{
if (!_disposed)
{
if (disposing)
{
// Dispose managed resources.
}
// Dispose unmanaged resources.
ClosePort();
WrappedSerialPort.DataReceived -= SerialPortDataReceived;
_wrappedSerialPort.Dispose();
_disposed = true;
}
}
~SerialPortAdapter()
{
Dispose(false);
}
#endregion
}
编辑:是否有必要调用此方法,或者足以仅调用_wrappedSerialPort.Dispose();?
ClosePort();
WrappedSerialPort.DataReceived -= SerialPortDataReceived;
_wrappedSerialPort.Dispose();
最佳答案
Henk Holterman的回答是正确的:SerialPort是一个托管资源,它本身拥有一个非托管资源,因此实现了IDisposable
。
由于包装器拥有SerialPort,因此它间接拥有SerialPort的非托管资源,因此必须实现IDisposable。您的实现是错误的,仅当disposing
为true时,才应处置拥有的SerialPort实例,因为它是托管资源。
它应按以下方式实现:
private void Dispose(bool disposing)
{
if (!_disposed)
{
if (disposing)
{
// Dispose managed resources.
ClosePort();
WrappedSerialPort.DataReceived -= SerialPortDataReceived;
_wrappedSerialPort.Dispose();
}
_disposed = true;
}
}
而且,正如Henk Holterman指出的那样,如果您直接拥有非托管资源,则只需要一个析构函数,而在这里不是这种情况,并且可以通过摆脱析构函数来简化IDisposable实现。
关于c# - .NET中的SerialPort是非托管资源吗?我包装好的类(class)正确吗?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/4826702/