菜鸟学习历程【10】机器字节序、大小端的判断与修改

机器字节序、大小端的判断与修改
首先,看一下下面这张图
       我们定义一个整型变量a,假设其起始地址为0x100,结束地址为0x103,那么0x100对应低地址,0x103对应高地址,对于存放的二进制数据,最前面“0000 0000”为高字节,最后的“0000 0001”对应低字节,但究竟是高字节存放在低地址还是高地址,各个机器不同,因此会有不同的情况。
       当高字节存放在低地址时,为大端,高字节存放在高地址为小端。
       那么我们如何判断机器的字节序呢?
       我们可以使用联合体,来解决这个问题,因为联合体中的成员共用一段内存。代码如下:
      
#include <stdio.h>

union test
{
    short val;
    char array[sizeof(short)];
};

int main()
{
    union test t;
    t.val = 0x0102;
    if(t.array[0] == 2 && t.array[1] == 1)
    {
         printf("Little Endian\n");
    }
    else  if(t.array[0] == 1 && t.array[1] == 2)
    {
         printf("Big  Endian\n");
    }
    else 
    {
         printf("Unkown\n");
     }
       return 0;
}

那么我们如何实现大小端的转换呢?

我们使用位运算和移位实现这个问题。

首先,我们需要知道,是如何移位的,例如,unsigned int a;

假设a 的二进制为:1011 1000 0001 1100 1110 0011 1011 0011
 
a & 0x0000 00ff <<  24           1011 0011 0000 00000000 0000 0000 0000

a & 0x0000 ff00 <<  8             0000 0000 1110 0011 0000 0000 0000 0000

a & 0x00ff 0000 >>  8            0000 0000  0000 0000 0001 11000000 0000

a & 0xff00 0000 >> 24            0000 0000 0000 0000 0000 0000  1011 1000

#include <stdio.h>

int main()
{
    unsigned int a = 1;
    unsigned int b;
    b = (((a & 0x000000ff) << 24) | ((a & 0x0000ff00) << 8 ) | ((a & 0x00ff0000) >> 8) | 
    ((a & 0xff00000) >> 24));
    printf("%d\n", b);
     
    return 0;
}



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值