c c++大小端转换代码

cpu架构不同导致存在大端(Big Endian)和小端(Little Endian),所谓的大端模式,是指数据的低位保存在内存的高地址中,而数据的高位,保存在内存的低地址中;所谓的小端模式,是指数据的低位保存在内存的低地址中,而数据的高位保存在内存的高地址中。

可以使用如下的代码判断电脑的大小端

#include <stdio.h>
int main()
{
    short int x;
    char x0,x1;
    x=0x1122;
    x0=((char *)&x)[0];  //低地址单元
    x1=((char *)&x)[1];  //高地址单元
    printf("x0=0x%x,x1=0x%x",x0,x1);// 若x0=0x11,则是大端; 若x0=0x22,则是小端......
    return 0;
}

 为什么需要处理大小端的原因是数据会在网络上传播,如果数据不按照统一的标准,可能intel架构的电脑数据发送到arm的系统上就无法正确解析,因此文件格式在设计的时候就需要考虑这个问题,例如在intel + window10的系统上解析jpg格式文件,就需要处理大小端问题

#include <stdint.h>
uint16_t swap_u16(uint16_t input)
{
    return (uint16_t)(((input << 8) & 0xff00) | ((input >> 8) & 0xff));
}


uint32_t swap_u32(uint32_t input)
{
    uint16_t l16 = input & 0xFFFF;
    uint16_t h16 = (input >> 16) & 0xFFFF;
    return (((uint32_t)swap_u16(l16) << 16) & 0xFFFF0000)  | swap_u16(h16);
}


uint64_t swap_u64(uint64_t input)
{
    uint32_t l32 = input & 0xFFFFFFFF;
    uint32_t h32 = (input >> 32) & 0xFFFFFFFF;
    return (((uint64_t)swap_u32(l32) << 32) & 0xFFFFFFFF00000000)  | swap_u32(h32);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值