write by polaris(lz0ace@hotmail.com)
转载请注明作者
首先感谢玲对我的支持,在我最困难时是她帮助了我。声明一下,高手就不要看了,这篇文章只是随便写写,解决一些C编程新手的问题。 废话少说先看程序: ------------------------------start------------------------------------------ struct bit { unsigned a_bit:2;//为bit结构体中的a_bit成员分配两字节的空间 unsigned b_bit:2;//为bit结构体中的b_bit成员分配两字节的空间 unsigned c_bit:1;//为bit结构体中的c_bit成员分配两字节的空间 unsigned d_bit:1;//为bit结构体中的d_bit成员分配两字节的空间 unsigned e_bit:2;//为bit结构体中的e_bit成员分配两字节的空间 unsigned word:8; } main() { struct bit * p; unsigned int modword; printf("enter..\n"); scanf("%x",&modword); p=(struct bit * )&modword; printf("a_bit:%d\n",p->a_bit); printf("b_bit:%d\n",p->b_bit); printf("c_bit:%d\n",p->c_bit); printf("d_bit:%d\n",p->d_bit); printf("e_bit:%d\n",p->e_bit); } ------------------------------end--------------------------------------------- 运行程序,输入96答案是 a_bit:2 b_bit:1 c_bit:1 d_bit:0 e_bit:2 scanf接收十六进制的96后在内存中的储存为二进制10010110,注意这里是unsigned形式,没有符号位。之后P指针被赋moduword的地址。由于P指针指向的空间是bit型,所以打印p->a_bit是既为modword的第一个两字节空间的值。按常理b_bit所占区域的值应该是二进制01,但是打印b_bit时输出的竟然2。我晕!!! 情急之下我又试了95输出为1,1,1,,0,2再看97,输出3,1,1,0,2。渐渐明白了,原来在C编译器中以整形变量的右端作为低地址的。 本文遇到的问题可能新手们会再次遇到,希望可以作为参考。
|