QByteArray的外部与内部声明

External vs internal declaration of QByteArray

本文关键字:内部 声明 外部 QByteArray      更新时间:2023-10-16

我目前对QSerialPort有一些问题:当我使用一个看起来像的示例中的函数时

QKeyEvent *e;
emit getData(e->text().toLocal8Bit());
connect(console, SIGNAL(getData(QByteArray)), this, SLOT(writeData(QByteArray)));
void MainWindow::writeData(const QByteArray &data)
{
    qDebug() << "Data is to write: " << data;
    serial->write(data);
}

则接收设备可以使用该数据。但当我将函数writeData()更改为时

void MainWindow::writeData(const QByteArray &data)
{
    QString a = "Q";
    QByteArray b = a.toLocal8Bit();
    serial->write(b);
}

接收设备不能与接收到的数据一起工作。这两种方法的区别在哪里
更新:我发现,显然只有在键入字母后按Enter,数据才能有效传输。不知怎的,'n'在从QStringQByteArray的转换中丢失了。我该怎么保管?

您应该像下面的一样在Qstring中添加一个回车

QString a = "Qx00D";

在您给出的示例中,QString中没有"\n"!它不会迷路,它一开始就不在那里。

如果需要换行,则将String构造为QString a = "Qn"

您也可以直接从字符数组构建QByteArray,而不是通过字符数组->QString->QByteArrray转换序列,如下所示:

QByteArray b("Qn");

编辑:我意识到,你只是发送字母"Q"的人为例子可能是一次调试尝试,而不是你真正的代码。事实上,你正在从发射QByteArray的其他信号中获得数据作为QByteArray。您正在接收的QByteArray中不能包含换行符。如果您正在读取文件或用户输入,则这是正常的。大多数类似readline的函数都会去掉后面的换行符。如果总是需要换行,您可以在WriteData方法中简单地执行以下操作:

void MainWindow::writeData(const QByteArray &data)
{
    serial->write(data);
    serial->write("n");
}

如果传入的QByteArray有时在末尾有换行符,有时没有,并且您的接收设备无法处理冗余换行符,那么您需要检查数据是否以换行符结尾,如果没有,则只写入"\n"。

如果你把QByteArray做成这个会怎么样

QByteArray b(&a);