看别人提问 我的回答 有问题 验证下
#include <stdio.h>
#include <string.h>
typedef unsigned char uint8_t;
typedef unsigned short uint16_t;
typedef unsigned int uint32_t;
struct pid_tag
{
unsigned int inactive:1;
//unsigned int :1;
//unsigned int refcount:6;
unsigned int :0;
short pid_id;
struct pid_tag *link;
};
int main()
{
printf("%d\r\n",sizeof(struct pid_tag));
}
//此时是12 它是4+2+4 中间的short是2但是被拉长4对齐就是4-4-4
//维持源码 如果删除short pid_id;结果是8
//维持源码 如果修改short pid_id;为int 结果是12
//
开始考虑位域 我当时说unsigned int :0;可以不要效果一样
///实际测试发现 维持源码 一旦不要unsigned int :0;的话 那么结果是8!
///为什么从12-->8了?因为前面位域正好是1+1+6是一个char 是一个字节
///那就是1-2-4这样的结构体 变成8了!!!!此时继续修改代码short改为int结果是12因为是1-4-4嘛
/维持源码删除/unsigned int :1;结果是12 WHY?
/其实写成
/*
struct pid_tag
{
unsigned int inactive:1;
unsigned int :0;
short pid_id;
struct pid_tag *link;
};
int main()
{ printf("%d\r\n",sizeof(struct pid_tag));}
*/
//结果也是12 因为那个unsigned int :0的功能是一个U32后面全部写0!!!