1

QByteArray2 つの浮動小数点数を表す 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"

関連する問題を読んだことがありますが、私の場合はそれを実装するのに適切に理解できません。

以下は私の現在の解決策ですが、複雑すぎると思います。それを行う簡単な方法があります。

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;
}
4

1 に答える 1