面试:大小端的判断与大小端的转换

本文深入探讨了内存中数据的存放顺序及其对CPU的影响,并通过实例展示了如何利用联合体特性来判断CPU的内存读写方式是Big-endian还是Little-endian。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#include<stdio.h>
#define uint32 unsigned int
#define uint16 unsigned short int
#define BigtoLittle16(A)    ((((uint16)(A) & 0xff00) >> 8) | \
                            (((uint16)(A) & 0x00ff) << 8))
#define BigtoLittle32(A)    ((((uint32)(A) & 0xff000000) >> 24) | \
                            (((uint32)(A) & 0x00ff0000) >> 8) | \
                            (((uint32)(A) & 0x0000ff00) << 8) | \
                            (((uint32)(A) & 0x000000ff) << 24))
/**************************************************************
联合体uniON的存放顺序是所有成员都从低地址开始存放,
利用该特性就可以轻松地获得了CPU对内存采用Little-endian还是Big-endian模式读写。
****************************************************************/
int checkCPUendian()
{
    union
    {
        unsigned int a;
        unsigned char b;
    }c;
    c.a = 1;
    return (c.b == 1);
}
/*return 1 : little-endian, return 0:big-endian*/


int main()
{
    unsigned int a=0x12345678;
    printf("\n/*return 1 : little-endian, return 0:big-endian*/\n");
    printf("\ncheckCPUendian()->%d\n",checkCPUendian());
    printf("before:0x%0x\n",a);
    BigtoLittle32(a);
    a=BigtoLittle32(a);//注意:不能只写成BigtoLittle32(a);a值若想改变,就应该成为左值
    printf("after:0x%0x\n",a);

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值