QDataStream 读取到 QVector
QDataStream read to QVector
我有一个 QByteArray
包含代表两个浮点数的 8 位,将 QDataStream
读取为 QVector<float>
的正确且最简单的方法是什么?
代码:
QByteArray ByteFloatArray;
QVector<float> qVecfloat;
ByteFloatArray.append(0x41);
ByteFloatArray.append(0x31);
ByteFloatArray.append(0x99);
ByteFloatArray.append(0x9A); // 4 bits float == 11.1
ByteFloatArray.append(0x41);
ByteFloatArray.append(0x31);
ByteFloatArray.append(0x99);
ByteFloatArray.append(0x9A); // 4 bits float == 11.1
QDataStream myStream(ByteFloatArray);
myStream.setFloatingPointPrecision(QDataStream::SinglePrecision);
myStream >> qVecfloat;
上面的代码给出:
STD:: bad_alloc at memory location"
我已经阅读了相关问题,但我无法正确理解它们以在我的案例中实施它。
以下是我目前的解决方案,但我认为它过于复杂,有一种更简单的方法可以做到这一点:
QVector<float> qVecfloat;
float myFloat;
for (int i = 0; i < 2; i++) {
QDataStream myStream(ByteFloatArray);
myStream.setFloatingPointPrecision(QDataStream::SinglePrecision);
myStream >> myFloat;
qVecfloat.append(myFloat);
ByteFloatArray.remove(0, 4);
qDebug() << "size " << qVecfloat.size() << " : " << qVecfloat;
}
您可以在循环中使用 QDataStream::atEnd() 并像这样读取 float
数据:
QDataStream myStream( ByteFloatArray );
myStream.setFloatingPointPrecision( QDataStream::SinglePrecision );
float f = 0.0f;
while ( !myStream.atEnd() )
{
myStream >> f;
qVecfloat.append( f );
}
qDebug() << qVecfloat;
输出:
QVector(11.1, 11.1)
我有一个 QByteArray
包含代表两个浮点数的 8 位,将 QDataStream
读取为 QVector<float>
的正确且最简单的方法是什么?
代码:
QByteArray ByteFloatArray;
QVector<float> qVecfloat;
ByteFloatArray.append(0x41);
ByteFloatArray.append(0x31);
ByteFloatArray.append(0x99);
ByteFloatArray.append(0x9A); // 4 bits float == 11.1
ByteFloatArray.append(0x41);
ByteFloatArray.append(0x31);
ByteFloatArray.append(0x99);
ByteFloatArray.append(0x9A); // 4 bits float == 11.1
QDataStream myStream(ByteFloatArray);
myStream.setFloatingPointPrecision(QDataStream::SinglePrecision);
myStream >> qVecfloat;
上面的代码给出:
STD:: bad_alloc at memory location"
我已经阅读了相关问题,但我无法正确理解它们以在我的案例中实施它。
以下是我目前的解决方案,但我认为它过于复杂,有一种更简单的方法可以做到这一点:
QVector<float> qVecfloat;
float myFloat;
for (int i = 0; i < 2; i++) {
QDataStream myStream(ByteFloatArray);
myStream.setFloatingPointPrecision(QDataStream::SinglePrecision);
myStream >> myFloat;
qVecfloat.append(myFloat);
ByteFloatArray.remove(0, 4);
qDebug() << "size " << qVecfloat.size() << " : " << qVecfloat;
}
您可以在循环中使用 QDataStream::atEnd() 并像这样读取 float
数据:
QDataStream myStream( ByteFloatArray );
myStream.setFloatingPointPrecision( QDataStream::SinglePrecision );
float f = 0.0f;
while ( !myStream.atEnd() )
{
myStream >> f;
qVecfloat.append( f );
}
qDebug() << qVecfloat;
输出:
QVector(11.1, 11.1)