嗯...为什么当我打印 sizeof(struct MyStruct)
时,它会为此代码输出 3(而不是 2)?
#pragma pack(push, 1)
struct MyStruct
{
unsigned char a : 6;
union
{
struct
{
unsigned int b : 9;
};
};
};
#pragma pack(pop)
以防万一,我在 Windows 7 x64 上运行 MinGW GCC 4.5.0,但老实说,结果对我来说很奇怪,我认为编译器和操作系统在这里并不重要。 :\
最佳答案
您不能让字段以字节未对齐的地址开始。 你期待:
6 bits + 9 bits -> 15 bits -> 2 bytes
但是你得到的是:
6 bits -> 1 byte
9 bits -> 2 bytes
total -> 3 bytes
数据存储为:
| 1 byte | 2 byte |3 byte |
aaaaaaXX bbbbbbbb bXXXXX
当你期待:
| 1 byte | 2 byte |
aaaaaabb bbbbbbbX
编辑: 根据以下评论进行澄清:
union (和包含的结构)必须是字节对齐的。内容只有 9 位并不重要, union/结构本身是完整的 16 位。请注意,您不能执行以下操作:
struct MyStruct
{
unsigned char a : 6;
union
{
struct
{
unsigned int b : 9;
} c:9;
} d:9;
};
因为 C 不允许您指定整个结构的位大小。
关于c - C 中的位域,其结构包含结构的并集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5055142/