2

SerialPort试图从课堂上正确阅读时,我有点头疼。

如果我使用阻塞方法ReadLineReadExisting应用程序像魅力一样工作,但我的一些值会因为string转换而受到影响。即:0xFC字节显示为0x3F(“?”)。我的猜测是 ASCII 范围之外的任何值也会丢失。

我尝试使用该Read(byte[] buffer,int offset,int count)方法SerialPort.ReadBufferSize来查看我应该读取多少字节,但它总是返回几乎 5000 ,即使我试图从 UART 仅读取 8 个字节。我必须创建一个函数来将此数组修剪为更小的数组并使用它。即使效率不高,我也可以使用此方法,但有时使用它会导致数组越界执行错误。调试后我发现当我读取一个完整的零数组时会发生这种情况。

我的最后一次尝试是使用以下代码:

private void DataRec(object sender, SerialDataReceivedEventArgs e)
{
    SerialPort sp = (SerialPort)sender;
    byte[] myarray = new byte[200];
    int pos = 0;
    bool eol = false;
    while (!eol)
    {
        myarray[pos++] = (byte) sp.ReadByte();
        if (myarray[pos] == 0x7E) eol = true;
    }

    byte[] newarray = Recorta(myarray);
    this.Dispatcher.Invoke(new AtualizaCallBack(this.atualiza), new object[] { newarray });
    sp.DataReceived -= DataRec;
}

调试时,我永远不会到达byte[] newarray = Recorta(myarray);断点,但没有错误。奇怪的是,每当事件再次触发(我告诉 UART 向我发送一个数据包)时,pos变量不会从零开始。

关于可能发生什么的任何想法?

有一点值得一提:

  • 0x7E "~" 是我的行尾字符
  • 200 是我一次收到的最大字节数
  • UART代码一次发送一个字节的数据,但只有在收到正确的请求后
4

2 回答 2

3

您只是使用了 SerialPort 类的错误成员。ReadLine() 和 ReadExisting() 返回字符串,但您的数据不能存储在字符串中。0xFC 没有 ASCII 字符代码,因此它只是放弃并产生“无法转换该字节”值。这是0x3F,一个问号。

同样,ReadBufferSize 是一个固定数字,除非您重新分配该值。它设置了串行端口驱动程序在程序读取之前用来存储接收到的字节的缓冲区的大小。充其量你会对 BytesToRead 属性感兴趣。它告诉您在该缓冲区中有多少字节可用于读取。

只需使用 SerialPort.Read() 方法。一定要注意它的返回值,它告诉你读取了多少字节。这几乎总是一个小数字,通常是一两个字节。串行端口很慢。您需要继续阅读,直到您得到设备的完整响应。在你的情况下,当你得到那个 0x7E 时。

于 2013-09-09T12:44:54.830 回答
1

试试这个。我认为大多数情况下您没有正确实施它。

    private byte[] ReadLine(SerialPort serialPort)
    {
        byte[] buffer = new byte[4096];
        int count = 0;

        for (; count < buffer.Length; count++)
        {
            buffer[count] = (byte)serialPort.ReadByte();
            if (buffer[count] == 0x7E) break;
        }

        return buffer.Take(count);
    }
于 2013-09-09T12:55:00.843 回答