我正在开发一个从 600Hz 的传感器接收数据的 Windows 应用程序。在五分之二的情况下,我的 IO 线程成功地从传感器读取了 4 个字节的数据并将其传递给 GUI 线程。
问题是五分之三,QSerialPort 有莫名其妙的超时,其中 QSerialPort 的 waitForReadyRead() 返回 false 并且 serial.errorString() 有超时错误。在这种情况下,它永远不会读取数据。如果我从串行端口读取,尽管出现超时错误,我将在下一个 waitForReadyRead 中读取 2000+ 字节的数据,这些数据将以块的形式交付,从而使我的应用程序的实时数据接收方面过时。
我试过使用串口的 readyRead() 信号,但它表现出相同的行为,即。如果出现超时错误,则不会触发 readyRead() 信号。
更新:我能够重现使用非阻塞读取的 Qt 终端示例([QT_INSTALL_EXAMPLES]/serialport/terminal)的问题。该错误的频率要少得多,但它肯定仍然存在。
更新:使用串行端口监视器,我可以看到当它卡住时,Qt 终端示例卡在 IOCTL_SERIAL_WAIT_ON_MASK 上,我的示例卡在 IOCT_SERIAL_WAIT_ON_MASK 之后的 IRP_MJ_WRITE DOWN 上。其他终端软件从未发生过这种情况,这让我认为问题肯定出在 Qt 上。
void IOThread::run(){
QSerialPort serial;
serial.setPortName(portname)
serial.setBaudRage(QSerialPort::Baud115200);
serial.setStopBits(QSerialPort::OneStop)
serial.setParity(QSerialPort::NoParity);
serial.setDataBits(QSerialPort::Data8);
serial.setFlowControl(QSerialPort::NoFlowControl);
if(!serial.open(QIODevice::ReadWrite)
{
qDebug() << "Error Opening Port";
return;
}
else
{
qDebug() << "Error Message: " << serial.errorString() // prints "Unknown Error"
}
while(true)
{
if(serial.waitForReadyRead(1000))
{
qDebug() << "Normal read";
reception_buffer = serial.readAll();
}
else
{
qDebug() << "Timeout";
/* serial.readAll() here will read nothing but force next read to read huge chunk of data */
continue;
}
}
// Process data...
}