C++ 将包含二进制数据的QByteArray按值传递给函数
所以我正在开发一个大型程序,它可以处理QbyteArray中存储的二进制数据。今天,我意识到当我通过值将QByteArray传递给函数时C++ 将包含二进制数据的QByteArray按值传递给函数,c++,qt,qbytearray,C++,Qt,Qbytearray,所以我正在开发一个大型程序,它可以处理QbyteArray中存储的二进制数据。今天,我意识到当我通过值将QByteArray传递给函数时 void myFunc(QByteArray data) { // Do stuff } 如果我的QByTeRayx在二进制流中间有一个0x0,比如 0xA5 0x200x04 0x00 0x52 。当QByteArray被传递到函数中时,0x52被切断 我想象我可以简单地将QByteArray按值传递到函数中,但在某些情况下,我需要数组的副本(用于数据持
void myFunc(QByteArray data)
{
// Do stuff
}
如果我的QByTeRayx在二进制流中间有一个0x0,比如<代码> 0xA5 0x200x04 0x00 0x52 。当QByteArray被传递到函数中时,0x52被切断
我想象我可以简单地将QByteArray按值传递到函数中,但在某些情况下,我需要数组的副本(用于数据持久性或添加到队列等),不幸的是,我有很多很多行代码,这些函数在其中传递复制的QByteArray 因此,我想知道是否有办法重载赋值运算符(或使用其他方法)在两个QbyteArray之间复制数据,而不将0x00项视为以null结尾的字符串字符。我正试图找到解决这个问题的最简单方法,而不必完全掏空我的程序并重做所有的函数。是否有更好的替代数据类型可供我使用(我可以快速查找/替换数据类型,或者使用一些函数将它们封装起来) 更新:为演示问题添加了精简示例int main(int argc, char *argv[])
{
QApplication a(argc, argv);
QByteArray data = QByteArrayLiteral("\xA5\x20\x04\x00\x52");
doStuff(data);
return a.exec();
}
void doStuff(QByteArray theData)
{
// theData will contain only 0xA5 0x20 0x04 0x00 if you look from in here
}
更新2:
好的,显然,在测试了上面的示例之后。它确实有效。但是,我在线程中处理的真实场景需要进行更多测试。一旦我进一步缩小问题范围,它将更新…我认为它与通过值传递
QByteArray
没有任何关系,但更像是初始化数组的方式。考虑呃这个例子,
QByteArray data("\xA5\x20\x04\x00\x52");
qDebug( data.toHex() );
QByteArray data2;
data2.append( static_cast<char>( 0xA5 ) );
data2.append( static_cast<char>( 0x20 ) );
data2.append( static_cast<char>( 0x04 ) );
data2.append( static_cast<char>( 0x00 ) );
data2.append( static_cast<char>( 0x52 ) );
qDebug( data2.toHex() );
使用它在0端切掉的字符串初始化它。这对于QByteArray::toStdString()
也适用
编辑:
正如弗兰克指出的那样:
QByteArray data("\xA5\x20\x04\x00\x52", 5);
qDebug( data.toHex() );
确实会提出人们的期望:
a520040052
如果您的MRE没有重现问题,那么它不是MRE,因此您必须处理它。这是因为构造函数有一个参数
size
,默认为-1。然后如果大小为负数,则假定数据指向以“\0”结尾的字符串,其长度是动态确定的。结尾的\0字符不被视为字节数组的一部分“。因此,如果要将nul字节视为普通字符,则需要显式传递数组大小。谢谢。我在正确打印QByteArray中的字节时也遇到问题,因此这非常有用!”!
a520040052