深秋的落叶
ARM && Linux kernel
今天看到一本书中有与下面这种结构体类似的使用形式:
typedef struct some_dev{
        unsigned int var1 : 8;
        unsigned int var2 : 13;
}
特意在VC++ 6.0中做了几个测试:
测试1:
#include <stdio.h>
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 <stdio.h>
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 <stdio.h>
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数;
来确定结构体类型的成员变量的值所占的字位数,如果在实际应用中,该变量的值超出了在声明它时所声明的字位数,那么溢出的部分将会丢失。


posted on 2008-05-21 22:18  刘伟_luvi  阅读(1361)  评论(0编辑  收藏  举报