QDataStream读取到QVector

频道I。

我有一个QByteArray包含两个浮点数的8位,读的正确和最简单的方法QDataStreamQVector<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在内存位置“

我已经阅读了相关的问题,但是我无法正确理解它们以实现我的情况。

以下是我当前的解决方案,但我认为它过于复杂,并且有一种更简单的方法可以做到这一点:

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)

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章