我想将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));
有人可以告诉我如何正确地做到这一点吗?
答案 0 :(得分:12)
您可以使用QVector::constData
获取指向向量中包含的(const)原始数据的指针。但是,您还需要将大小乘以单个条目的大小,即sizeof(double)
。您之后不需要像代码那样循环。
QByteArray data = QByteArray::fromRawData(
reinterpret_cast<const char*>(vec.constData()),
sizeof(double) * vec.size()
);
您还可以使用QDataStream
进行转换,从而产生更清晰的代码,同时也可以处理潜在的byte ordering issues。
QByteArray data;
QDataStream stream(&data, QIODevice::WriteOnly);
for (auto x : vec)
stream << x;
答案 1 :(得分: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()。 请看他的回复。
答案 2 :(得分:0)
今天这种转换更简单:
x
答案 3 :(得分: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的其他类型。