1

我想转换QVector<double>QBytearray,但我不知道如何做到这一点。我试过了,但程序崩溃了:

QVector<double> vec;
QByteArray arr = QByteArray::fromRawData(reinterpret_cast<const char*>(vec),vec.size());
for(int i = 0; i< vec.size(); i++)
    arr.append(reinterpret_cast<const char*>(vec.data(&numberOfData),sizeof(double));

有人可以告诉我如何正确地做到这一点吗?

4

4 回答 4

12

您可以使用QVector::constData来获取指向向量中包含的 (const) 原始数据的指针。但是,您还需要将大小乘以单个条目的大小,即sizeof(double). 之后您不需要像在代码中那样循环。

QByteArray data = QByteArray::fromRawData(
        reinterpret_cast<const char*>(vec.constData()),
        sizeof(double) * vec.size()
    );

您还可以使用QDataStream来进行转换,从而生成更简洁的代码,这还可以解决潜在的字节顺序问题

QByteArray data;
QDataStream stream(&data, QIODevice::WriteOnly);
for (auto x : vec)
    stream << x;
于 2014-11-10T12:18:04.970 回答
1

您必须通过本机数组,因此您的 QByteArray 将接收一系列连续字节。

double *bytes = new double[vec.size()];
for (int i = 0; i < vec.size(); ++i) {
   bytes[i] = vec[i];
}
QByteArray array = QByteArray::fromRawData(reinterpret_cast<void*>(bytes));
delete []bytes;

免责声明:未经测试的代码。

- - 更新 - -

正如 leemes 正确指出的那样,您不需要分配和复制字节数组,QVector 已经为原始数据提供了两个访问函数。所以你可以简单地使用 data() 和 constData()。请看他的回复。

于 2014-11-10T12:07:16.270 回答
0

对此我也有些恼火。基于此处的其他答案,我想出了这个:

template<typename data_type>
QByteArray toByteArray(data_type data) {
    QByteArray bytes;
    QDataStream stream(&bytes, QIODevice::WriteOnly);
    stream << data;
    return bytes;
}

这应该让您编写以下代码:

QVector<double> vec{1, 2, 3, 4};
auto bytes = toByteArray(vec);

并且也适用于支持流式传输到 QDataStream 的其他类型。

于 2018-10-26T07:43:29.063 回答
0

今天,这种转换更加简单:

QVector<double> vec;
// populate vector
QByteArray data;
QDataStream stream(&data, QIODevice::WriteOnly);
stream << vec;
于 2016-04-28T22:02:21.713 回答