今天看到一本书中有与下面这种结构体类似的使用形式:
typedef struct some_dev{
unsigned int var1 : 8;
unsigned int var2 : 13;
}
特意在VC++ 6.0中做了几个测试:
测试1:
#include
typedef struct test1{
unsigned int testint:8;
char *p :32;
int test2 : 16;
} test;
int main()
{
test obj;
obj.testint = 32;
obj.test2 = 256;
char *t="hello world!";
obj.p=t;
printf("\n\t%u.......%d.........%s", obj.testint, obj.test2 , obj.p);
return 0;
}
编译结果:
struct_t.obj - 2 error(s), 0 warning(s)
error C2033: 'p' : bit field cannot have indirection
error C2034: 'p' : type of bit field too small for number of bits
即便指针p的长度为32或者64,编译都不能通过。
所以我们可以这样认为:
1:指针类型变量不能指定所占的位数
测试2:
#include
typedef struct test1{
unsigned int testint:8;
char *p;
int test2 : 16;
} test;
int main()
{
test obj;
obj.testint = 32;
obj.test2 = 256;
char *t="hello world!";
obj.p=t;
printf("\n\t%u.......%d.........%s\n", obj.testint, obj.test2 , obj.p);
return 0;
}
编译链接均没有错误警告信息,运行结果为:
32.......256.........hello world!Press any key to continue
测试3:
#include
typedef struct test1{
unsigned int testint:8;
char *p;
int test2 : 16;
} test;
int main()
{
test obj;
obj.testint = 256; //这里修改obj.testint的值为256
obj.test2 = 256;
char *t="hello world!";
obj.p=t;
printf("\n\t%u.......%d.........%s\n", obj.testint, obj.test2 , obj.p);
return 0;
}
运行结果为:
0.......256.........hello world!
可以看到,成员变量obj.testint的运行结果已经变成“0”.
为什么呢??
原来在结构体声明的时候,我们给obj.testint的bit数声明为8b的unsigned类型,它可以表示的最大值为(2^8 - 1),即255,我们在第三个测试中,给它赋值256,它的二进制值为:1 0000 0000 b,系统在保留时,只保留了后8位的值,对溢出的位,进行了截取抛弃处理,所以这里输出的结果为0.
而输出sizeof(struct test)的结果为:12
也就是说这三个成员变量各占4个字节。
再测试几组数据,结果也都能证明下面的结论:
2. 在声明成员变量时,可以用
变量名 :bit数;
来确定结构体类型的成员变量的值所占的字位数,如果在实际应用中,该变量的值超出了在声明它时所声明的字位数,那么溢出的部分将会丢失。
阅读(2354) | 评论(0) | 转发(0) |