原帖:http://bbs.csdn.net/topics/392021186?page=1
#include <stdio.h>
typedef union{
unsigned int u;
struct
{
unsigned char a :1;
unsigned char b :1;
unsigned char c :6;
unsigned char d :1;
} ST;
}UN;
int main()
{
UN.ST.u = 0;
UN.ST.a = 1;
UN.ST.b = 2;
UN.ST.c = 3;
UN.ST.d = 4;
printf("%d\n", UN.u);
return 0;
}
运行结果是13。
1)注意联合体的定义,就是组成联合体的变量共用一个空间。这个 例子中变量u和ST共用一个空间
2)现在用的pc机大多为小段结构,我的结果13也是在小段机测试的,如果架构改变,结果可能不同
3)基于小段结构,数据的低字节保存在内存的低地址中,ST占用9位(Bit),与变量u(32Bit)共用低位的9位
4)根据小段结构,变量a的地址应该最低,往后依次是b,c,d
5)un.u = 0; 执行这一步,变量所对应的空间二进制全部为0,即00000000 00000000 00000000 00000000
6)un.ST.a = 1;执行这一步,变量最后一位变化,即00000000 00000000 00000000 00000001
7)un.ST.b = 2;执行这一步,由于1位空间无法存储2,所以赋值被截断,原值不变
8)un.ST.c = 3;执行这一步,变量第3-8位发生变化,变量值变为00000000 00000000 00000000 00001101
9)un.ST.d = 4;执行这一步,由于1位空间无法存储4,所以赋值被截断,原值不变
10)所以最终的结果就是00000000 00000000 00000000 00001101
11)printf("%d\n", un.u); 输出结果就是13
能解释下“由于1位空间无法存储2,所以赋值被截断”是什么意思吗?
1. 结构中的u和ST是共用一段内存,所以你修改了u,则ST的内容自动变化,同样如果你修改了ST的内容,则u的内容也自动变化.这就是联合体
2. unsigned char a :1;这种定义方式,是按位进行定义的,即a只占用一个位,同样b和d都只占用一位,所以如果这三个变量你赋值大于1的话,则自动被截断为1位,即除了低1位有效之外,其它高位的全部被丢弃。按位定义的,和这个变量的类型相关性不是很大,所以不是说a被定义成char就是8位。
3. 由于是联合体,所以你的main()中对u赋值之后,再对a\b\c\d赋值,结果u就被修改掉了