先介绍什么是大端法,小端法。
就是根据字节顺序在内存中的排列顺序的差异的两种标准,小端法指的是机器选择在存储器重按照从低有效字节到高有效字节的顺序存储对象。大端法按照从高有效字节到低有效字节的顺序存储对象。比如存储0x01234567,我们看看大端法和小端法存储的特点
(图有一个错误 应该是0x01234567)
小端法的代表是Intel系列的处理器,大端法的代表是IBM,sun的处理器,标准不统一的后果就是当小端法机器产生的数据发送到大端法的服务器时,或者相反的方向,程序接收的字节变成了反方向的。
接下来我们来判断机器是大端还是小端的。
#include <stdio.h>
typedef unsigned char *byte_pointer;
void show_bytes(byte_pointer start, int len) {
int i;
for (i = 0; i < len; i++) {
printf("%.2x ", start[i]);
}
printf("\n");
}
void show_int(int x) {
show_bytes((byte_pointer)&x, sizeof(int));
}
int main()
{
int a = 1023;
show_int(a);
return 0;
}
我写了一段代码,show_bytes(byte_pointer, int)将字节从低到高每两位一组输出,show_int(int)取整数的地址,强制该地址指向byte_pointer,调用show_bytes()输出。
输出结果为ff 03 00 00,可知我机器的为小端机器,如果机器是大端系统,那输出的结果就是 00 00 03 ff。