C语言面试题——位域及大小端模式的理解

这里涉及大小端的问题,我记为

“小高高,小弟弟(低低)”,就是:

“小端模式,是指数据的高位保存在内存的高地址中,数据的低位保存在内存的低地址中”

这是记小端模式的,有点黄,不过好记!那么大端模式就和这个相反喽!!~~

接下来就看一道面试题:

#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=%d\n",i);
	printf("sizeof (short)= %d\n",sizeof(short));
	return 0;
}
a占4个bit、b占5个bit、c占7个bit,总共16bit,大小和short的一样大!执行完下面的三条语句之后
test.a=2;
test.b=3;
test.c=0;
内存分布如下:

这里x86是小端模式,所以数据分布式上面的,而不是我们理所当然的0010 00011 0000000!

i=*((short *) &test);
这句话执行之后:把test整个转换成一个short的变量,然后再赋值给int型的i,i能够容纳*((short*) &test),那么i的值就是

那么i的值就是1*32+1*16+2=50喽!计算式以0x(00.....00110010)计算哦!~~

以上运行的结果是在x86平台下,编译器是mingw。



原文地址:https://www.cnblogs.com/CodeWorkerLiMing/p/12007693.html