小端模式(little-endian)的cpu对数据的存储是从低地址到高字节的,而大端模式(big-endian)模式操作数的存放方式是从高字节到低字节的。
一般的 x86数据存储是小端模式,arm是可选的,网络数据的存储是大端模式。
如何通过c程序来检测cpu的大小
有两种方式,一种是设置一个数,检测该数数的高位或地位来判断,这是直接的方法:假设一个16bit的short型x,在内存中的地址为0x0010,x的值为0x1122,那么0x11为高字节,0x22为低字节。对于 大端模式,就将0x11放在低地址中,即0x0010中,0x22放在高地址中,即0x0011中。小端模式,刚好相反。
#include<stdio.h>
#include<iostream.h>
void main()
{
short int x ;
char x0,x1 ;
x=0x1122 ;
x0= ((char*)&x)[0] ;
x1= ((char*)&x)[1] ;
if(x0==0x11)
printf("it is big-endian /n") ;
else
printf(" it is the little-endian /n ") ;
}
还可以利用union的特性,union中数据的存放顺序是从低地址开始存放的。
#include<stdio.h>
#include<iostream.h>
void main()
{
union w {
int m ;
char n ;
} ;
w ww ;
ww.m=1 ;
if(ww.n==1)
printf("it is little-endian ");
else
printf("it is libig-endian ");
}
我们在union中存放一个1,我们再指向该数据空间的低地址,如果该地址存放的数据还是1,那说明刚才将该数存放在int的地位上。
linux内核中的实现方法:
static union{char c[4],unsigned long l;}endian_test{{'l','?','?','b'}} ;
#define ENDIANNESS ((char)endian-test.l) 如果ENDIANNESS=‘l’则代表是小端 .是'b'则代表是大端.