这里涉及大小端的问题,我记为
“小高高,小弟弟(低低)”,就是:
“小端模式,是指数据的高位保存在内存的高地址中,数据的低位保存在内存的低地址中”
这是记小端模式的,有点黄,不过好记!那么大端模式就和这个相反喽!!~~
接下来就看一道面试题:
代码语言:javascript复制#include<stdio.h>
struct mybitfields
{
unsigned short a:4;
unsigned short b:5;
unsigned short c:7;
}test;
int main()
{
int i;
test.a=2;
test.b=3;
test.c=0;
i=*((short *) &test);
printf("i=%dn",i);
printf("sizeof (short)= %dn",sizeof(short));
return 0;
}
a占4个bit、b占5个bit、c占7个bit,总共16bit,大小和short的一样大!执行完下面的三条语句之后
代码语言:javascript复制test.a=2;
test.b=3;
test.c=0;
内存分布如下:
这里x86是小端模式,所以数据分布式上面的,而不是我们理所当然的0010 00011 0000000!
代码语言:javascript复制i=*((short *) &test);
这句话执行之后:把test整个转换成一个short的变量,然后再赋值给int型的i,i能够容纳*((short*) &test),那么i的值就是
那么i的值就是1*32 1*16 2=50喽!计算式以0x(00.....00110010)计算哦!~~
以上运行的结果是在x86平台下,编译器是mingw。