91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

C#串口類中異常處理與日志記錄

c#
小樊
87
2024-09-11 22:11:26
欄目: 編程語言

在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個停止位。然后發送一條消息,并接收響應,最后關閉串口。在整個過程中,所有的操作都會被記錄到日志中。

0
周至县| 上杭县| 江门市| 大连市| 天台县| 商都县| 雷州市| 孝义市| 六盘水市| 陆川县| 高密市| 肥城市| 东乌珠穆沁旗| 夏河县| 江永县| 彩票| 响水县| 新化县| 丰顺县| 南充市| 宁南县| 贵德县| 肃宁县| 买车| 桓仁| 玛纳斯县| 乐亭县| 南投市| 沾益县| 拉萨市| 高密市| 上犹县| 磐石市| 曲松县| 林口县| 保亭| 柘城县| 阜城县| 湘阴县| 河津市| 驻马店市|