-1

我有一个私有函数,它创建一个新的串行端口并打开它。有时,我会收到“安全句柄已关闭”异常,这会终止应用程序。现在,我一直在阅读一些可选的修复程序,并想从您的经验中了解,我的代码中真正的问题可能是什么。1)需要在_serialPort这个私有函数的范围之外定义变量。2) 串口的 readTimeout 属性不应该是无限的。3) 上面的 using 语句处理我的portName变量。

SerialPort _serialPort;
string[] devices = 
ConfigurationManager.AppSettings["GasAnalyzerDeviceName"].Split(',');
string portName;
using (var searcher = new ManagementObjectSearcher("SELECT * FROM Win32_PnPEntity"))
{
    portName = (from p in searcher.Get().Cast<ManagementBaseObject>()
                                let c = "" + p["Caption"]
                                where c != null
                                where devices.Any(d => c.Contains(d.Trim()))
                                from pn in SerialPort.GetPortNames()
                                where c.Contains(pn)
                                select pn).FirstOrDefault();

}
                if (portName == null)
                    portName = ConfigurationManager.AppSettings["GasAnalyzerPortName"];

                if (portName == null)
                    throw new Exception("Gas port not found");

                // Create a new SerialPort object with default settings.
                _serialPort = new SerialPort();

                // Set Serial port properties
                _serialPort.PortName = portName;
                _serialPort.BaudRate = 115200;
                _serialPort.DataBits = 8;
                _serialPort.Parity = Parity.None;
                _serialPort.StopBits = StopBits.One;
                _serialPort.Handshake = Handshake.None;
                _serialPort.ReadTimeout = Timeout.Infinite;//1200;
                _serialPort.WriteTimeout = 1200;

谢谢!

4

1 回答 1

0

我认为您可以放弃选项 2) 和 3)。

第一个是可能的候选者,但没有足够的代码可以确定:如果没有其他对您的引用,SerialPort它将成为垃圾收集的候选者。一旦它被垃圾收集,任何访问它的尝试都会导致异常,我希望NullReferenceException.

可能还有另一个原因:如果您的串行端口是通过例如 USB 设备模拟的,并且该设备在您的应用程序运行时被删除,则底层连接将被释放。当您尝试SerialPort在您的应用程序中使用它时,您将收到“安全句柄已关闭”异常。

于 2017-09-10T09:24:26.033 回答