0

我有一个 Visual Studio 2008 C++ 项目,我需要将一个 6 字节的数据数组解码为一个结构。

我的想法是做这样的事情:

#pragma pack( push, 1 )
struct Map 
{
    BYTE alpha    : 8;
    BYTE bravo    : 8;
    UINT charlie  : 24;
    BYTE delta    : 8;
    BYTE padding0 : 8;  // ensure correct byte boundary
    BYTE padding1 : 8;
};
#pragma pack( pop )
// sizeof( Map ) == 8 bytes

BYTE test_data[ 6 ] = { 0x07,     // alpha
                        0x0B,     // bravo
                        0x00,     // charlie high byte
                        0x00,     // charlie med byte
                        0x01,     // charlie low byte
                        0x33 };   // delta
Map map = { };
memcpy( &map, test_data, sizeof( test_data ) );
ASSERT( map.alpha == 0x07 );
ASSERT( map.bravo == 0x0B );
ASSERT( map.charlie == 0x01 );
ASSERT( map.delta == 0x33 );

但是,charliedelta中的数据永远不会正确。

有没有办法构建我的结构以使其正确,或者我是否坚持单独设置每个字段?

谢谢

4

2 回答 2

1

要以便携式方式执行此操作:

struct Map 
{
    BYTE alpha;
    BYTE bravo;
    UINT charlie;
    BYTE delta;

    Map(const BYTE data[6])
     : alpha(data[0])
     , bravo(data[1])
     , charlie((data[2] << 16) | (data[3] << 8) | data[4])
     , delta(data[5])
    {}
};

int main()
{
    BYTE test_data[ 6 ] = { 0x07,     // alpha
                0x0B,     // bravo
                0x00,     // charlie high byte
                0x00,     // charlie med byte
                0x01,     // charlie low byte
                0x33 };   // delta
    Map map(test_data);
    ASSERT( map.alpha == 0x07 );
    ASSERT( map.bravo == 0x0B );
    ASSERT( map.charlie == 0x01 );
    ASSERT( map.delta == 0x33 );
}
于 2012-04-30T17:26:01.920 回答
0

您不能天真地序列化复合类型。自己写吧:

std::tuple<char, char, unsigned int, char>
parse(char const * buf)
{
    return std::make_tuple(buf[0],
                           buf[1],
                           buf[2] + 256 * buf[3] + 256 * 256 * buf[4],
                           buf[5]);
}

当然,您必须将整数的字节序与您的序列化格式记录的字节序匹配,在我的示例中为 little-endian。

于 2012-04-30T17:14:08.720 回答