1

我正在尝试阅读标题。这是结构:

struct header
{
    uint32 offset;
    char identifier[4];
    uint32 unknown;
};

当我通过 memcpy 读取复制内存时,我可以正确输出偏移量(通常为大数)。

当使用带有字节数组的内置函数时,我读入了整个文件,然后使用以下方法获取前四个字节:

QByteArray offset = data.left(4);

然后我验证它已经正确复制,它有。

我的问题是将这些字节转换为适当的数据类型。我努力了:

 qDebug() << "Offset1:" << offset.toUShort();
    qDebug() << "Offset2:" << offset;
    qDebug() << "Offset3:" << offset.toHex();
    qDebug() << "Offset4:" << offset.toInt();
    qDebug() << "Offset5:" << offset.toLong();
    qDebug() << "Offset6:" << offset.toUInt();
    qDebug() << "Offset7:" << offset.toULong();
    qDebug() << "Offset8:" << offset.toULongLong();
    qDebug() << "Offset9:" << offset.toULong();

它们都没有输出正确的值。另一方面,当我只是 memcpy 然后使用:

qDebug() << "Offset:" << header.offset;

我得到了正确的值。从字节到 uint32 的转换中我缺少什么?

它与字节序有关吗?

4

1 回答 1

3

toInt() 等将字符串表示,如“100”转换为整数,而不是二进制表示。要将二进制文件转换回来,您必须强制转换它:

 const quint32 v = *reinterpret_cast<const quint32*>( offset.constData() );

请注意,由于字节顺序,这很脆弱。由于结构对齐(填充),带有结构的 memcpy 也不能安全地移植。更好地使用QDataStream或类似Boost 序列化Google Protocol Buffers的东西来实现更强大的序列化。

于 2013-01-22T08:52:51.880 回答