机器字节序、大小端的判断与修改
首先,看一下下面这张图
我们定义一个整型变量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 0011a & 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; }