• 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。



  • 相关阅读:
    (Lineup the Dominoes筛子)三维状压
    Halloween Costumes 玄学题
    jQuery之动画
    javascript之位置
    javascript之事件
    jQuery之DOM
    jQuery之选择器
    jQuery简介
    javascript之Bom简介
    javascript之DOM操作
  • 原文地址:https://www.cnblogs.com/CodeWorkerLiMing/p/12007693.html
Copyright © 2020-2023  润新知