传递包含二进制数据的 QByteArray 以按值运行
Passing QByteArray containing binary data to function by value
所以我正在开发一个大型程序来处理存储在 QByteArrays 中的二进制数据。今天,我意识到当我按值将 QByteArray 传递给函数时,例如
void myFunc(QByteArray data)
{
// Do stuff
}
如果我的 QByteArray 在二进制流的中间某处有一个 0x0,比如 0xA5 0x20 0x04 0x00 0x52
。当 QByteArray 被传递到函数中时,0x52 被截断。
我想我可以简单地将 QByteArray 按值传递给函数,但在某些情况下我需要数组的副本(用于数据持久性或添加到队列等),不幸的是,我有许多代码行,其中此类函数传递复制的 QByteArrays。
所以我想知道是否有任何方法可以重载赋值运算符(或使用其他方法)以在两个 QByteArray 之间复制数据而不将 0x00 项视为以空字符结尾的字符串字符。我正在尝试找到解决此问题的最简单方法,而不必完全破坏我的程序并重做所有功能。有没有我可以使用的更好的替代数据类型(我可以在其中快速执行 Find/replace,或者我可以将它们包装在其中的某些函数?
更新:向演示问题添加了精简示例
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:
OK,显然,在测试了上面的例子之后。它确实有效。但是,我在线程中处理的真实场景需要进行更多测试。一旦我进一步缩小问题范围就会更新...
我认为这与按值传递 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() );
输出为:
a52004
a520040052
用它在 0 结尾截断的字符串初始化它。这也适用于 QByteArray::toStdString()
.
编辑:
正如弗兰克指出的那样:
QByteArray data("\xA5\x20\x04\x00\x52", 5);
qDebug( data.toHex() );
确实会出所料:
a520040052
所以我正在开发一个大型程序来处理存储在 QByteArrays 中的二进制数据。今天,我意识到当我按值将 QByteArray 传递给函数时,例如
void myFunc(QByteArray data)
{
// Do stuff
}
如果我的 QByteArray 在二进制流的中间某处有一个 0x0,比如 0xA5 0x20 0x04 0x00 0x52
。当 QByteArray 被传递到函数中时,0x52 被截断。
我想我可以简单地将 QByteArray 按值传递给函数,但在某些情况下我需要数组的副本(用于数据持久性或添加到队列等),不幸的是,我有许多代码行,其中此类函数传递复制的 QByteArrays。
所以我想知道是否有任何方法可以重载赋值运算符(或使用其他方法)以在两个 QByteArray 之间复制数据而不将 0x00 项视为以空字符结尾的字符串字符。我正在尝试找到解决此问题的最简单方法,而不必完全破坏我的程序并重做所有功能。有没有我可以使用的更好的替代数据类型(我可以在其中快速执行 Find/replace,或者我可以将它们包装在其中的某些函数?
更新:向演示问题添加了精简示例
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:
OK,显然,在测试了上面的例子之后。它确实有效。但是,我在线程中处理的真实场景需要进行更多测试。一旦我进一步缩小问题范围就会更新...
我认为这与按值传递 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() );
输出为:
a52004
a520040052
用它在 0 结尾截断的字符串初始化它。这也适用于 QByteArray::toStdString()
.
编辑:
正如弗兰克指出的那样:
QByteArray data("\xA5\x20\x04\x00\x52", 5);
qDebug( data.toHex() );
确实会出所料:
a520040052