在C#中,使用串口通信時,可能會遇到各種異常情況。為了確保程序的穩定性和可靠性,我們需要對可能出現的異常進行處理,并記錄相關日志。以下是一個簡單的C#串口類,包含異常處理和日志記錄功能:
using System;
using System.IO.Ports;
using System.Text;
public class SerialPortHelper
{
private SerialPort _serialPort;
private string _portName;
private int _baudRate;
private Parity _parity;
private int _dataBits;
private StopBits _stopBits;
public SerialPortHelper(string portName, int baudRate, Parity parity, int dataBits, StopBits stopBits)
{
_portName = portName;
_baudRate = baudRate;
_parity = parity;
_dataBits = dataBits;
_stopBits = stopBits;
}
public void Open()
{
try
{
_serialPort = new SerialPort(_portName, _baudRate, _parity, _dataBits, _stopBits);
_serialPort.Open();
Log("Serial port opened successfully.");
}
catch (Exception ex)
{
Log($"Error opening serial port: {ex.Message}");
}
}
public void Close()
{
try
{
if (_serialPort != null && _serialPort.IsOpen)
{
_serialPort.Close();
Log("Serial port closed successfully.");
}
}
catch (Exception ex)
{
Log($"Error closing serial port: {ex.Message}");
}
}
public void Write(string data)
{
try
{
if (_serialPort != null && _serialPort.IsOpen)
{
_serialPort.Write(data);
Log($"Data sent: {data}");
}
}
catch (Exception ex)
{
Log($"Error sending data: {ex.Message}");
}
}
public string Read()
{
try
{
if (_serialPort != null && _serialPort.IsOpen)
{
string data = _serialPort.ReadLine();
Log($"Data received: {data}");
return data;
}
}
catch (Exception ex)
{
Log($"Error receiving data: {ex.Message}");
}
return null;
}
private void Log(string message)
{
Console.WriteLine($"[{DateTime.Now}] {message}");
}
}
在這個類中,我們使用了try-catch
語句來捕獲可能出現的異常,并在Log
方法中記錄日志。這樣,我們可以在控制臺或者其他地方查看到詳細的日志信息,以便于分析和調試。
使用這個類的示例代碼如下:
class Program
{
static void Main(string[] args)
{
SerialPortHelper serialPortHelper = new SerialPortHelper("COM1", 9600, Parity.None, 8, StopBits.One);
serialPortHelper.Open();
serialPortHelper.Write("Hello, World!");
string response = serialPortHelper.Read();
serialPortHelper.Close();
}
}
這個示例代碼創建了一個SerialPortHelper
實例,連接到COM1端口,波特率為9600,無奇偶校驗,8個數據位,1個停止位。然后發送一條消息,并接收響應,最后關閉串口。在整個過程中,所有的操作都會被記錄到日志中。