该文档实际上对此非常清楚:
void QIODevice::readyRead() [信号]
每次有新数据可用于从设备读取时,都会发出一次此信号。它只会在新数据可用时再次发出,例如当新的网络数据有效负载到达您的网络套接字时,或者当新的数据块已附加到您的设备时。
readyRead() 不会递归发出;如果您重新进入事件循环或在连接到 readyRead() 信号的插槽内调用 waitForReadyRead(),则不会重新发送该信号(尽管 waitForReadyRead() 仍可能返回 true)。
实现从 QIODevice 派生的类的开发人员注意:当新数据到达时,您应该始终发出 readyRead() (不要仅仅因为缓冲区中还有数据要读取而发出它)。不要在其他条件下发出 readyRead()。
这意味着并不能真正保证有多少数据可供读取,只是有一些数据可用。
如果您希望读取的数据多于一次读取的数据,您可以选择超时值和/或 readyRead。这取决于您要达到的目标。
请参阅我不久前为此操作编写的命令行异步读取器示例:
#include "serialportreader.h"
#include <QCoreApplication>
QT_USE_NAMESPACE
SerialPortReader::SerialPortReader(QSerialPort *serialPort, QObject *parent)
: QObject(parent)
, m_serialPort(serialPort)
, m_standardOutput(stdout)
{
connect(m_serialPort, SIGNAL(readyRead()), SLOT(handleReadyRead()));
connect(m_serialPort, SIGNAL(error(QSerialPort::SerialPortError)), SLOT(handleError(QSerialPort::SerialPortError)));
connect(&m_timer, SIGNAL(timeout()), SLOT(handleTimeout()));
m_timer.start(5000);
}
SerialPortReader::~SerialPortReader()
{
}
void SerialPortReader::handleReadyRead()
{
m_readData.append(m_serialPort->readAll());
if (!m_timer.isActive())
m_timer.start(5000);
}
void SerialPortReader::handleTimeout()
{
if (m_readData.isEmpty()) {
m_standardOutput << QObject::tr("No data was currently available for reading from port %1").arg(m_serialPort->portName()) << endl;
} else {
m_standardOutput << QObject::tr("Data successfully received from port %1").arg(m_serialPort->portName()) << endl;
m_standardOutput << m_readData << endl;
}
QCoreApplication::quit();
}
void SerialPortReader::handleError(QSerialPort::SerialPortError serialPortError)
{
if (serialPortError == QSerialPort::ReadError) {
m_standardOutput << QObject::tr("An I/O error occurred while reading the data from port %1, error: %2").arg(m_serialPort->portName()).arg(m_serialPort->errorString()) << endl;
QCoreApplication::exit(1);
}
}
在这种情况下,命令行阅读器示例将获取一次性传递的任何数据,但它不保证长度或任何东西。
另外,请注意,您评论背后的同步 API 与您询问的异步 API 没有多大意义。我指的m_serialPort->waitForReadyRead(200);
是这里。