1-大端小端的判断
大端 Big-Endian :是指数据的低位保存在内存的高地址中,而数据的高位保存在内存的低地址中
小端 Little-Endian :是指数据的低位保存在内存的低地址中,而数据的高位保存在内存的高地址中
为什么要区分大小端?
在计算机系统中,以字节为存储单元,每个地址单元都对应着一个字节,一个字节为8bit。在C语言中,不仅仅是一个字节来存储一个数据,除了一个字节的char,还有两个字节的short,四个字节的int等等。另外,对于位数大于8位的处理器,例如32位的处理器,由于寄存器的宽度大于一个字节,那么就有如何将多个字节进行排布的问题,于是就出现了大小端的问题。
大小端的优点
小端模式:强制转换数据不需要调整字节内容,1、2、4字节的存储方式一样。
大端模式:符号位的判定固定为第一个字节,容易判断正负。
常用的大小端
1.Interl x86系列芯片使用小端存储模式,ARM的芯片默认小端,但可以切换到大端,51单片机为大端模式;
2.网络上普遍采用大端模式,使用大端的CPU: power pc 、DSP … …
3.大小端是由CPU架构决定的,不是软件决定!!!
4.TCP/IP协议传输数据时,字节序默认大端
大小端的判断
方法一:
将int a=0x1122存起来,然后取得其地址,再将这个地址转为char* 这时候,如果是小端存储,那么char*指针就指向0x22;
#include<stdio.h>
void main()
{
short int a = 0x1122;//十六进制,一个数值占4位
char b = *(char *)&a; //通过将short(2字节)强制类型转换成char单字节,b指向a的起始字节(低字节)
if( b == 0x11)//低字节存的是数据的高字节数据
{
printf("大端模式");//是大端模式
}
else
{
printf("小端模式");//是小端模式
}
}
方法二:
定义变量int a=1;将 a 的地址拿到,强转成char*型,这时候就取到了a 的低地址,这时候如果是1就是小端存储,如果是0就是大端存储。
#include <stdio.h>
int main (){
int a=1;
char *p=(char *)&a;
if(*p==1){
printf("小端模式");
}else{
printf("大端模式");
}
return 0;
}
方法三:
定义联合体,一个成员是多字节,一个是单字节,给多字节的成员赋一个最低一个字节不为0,其他字节为0 的值,再用第二个成员来判断,如果第二个字节不为0,就是小端,若为0,就是大端。联合体union的存放顺序是所有成员都从低地址开始存放,而且所有成员共享存储空间。
#include <stdio.h>
union str{
short val;
char ch[sizeof(short)];
}b;
int main()
{
b.val=0x0102;
if(b.ch[0]==2 && b.ch[1]==1){
printf("小端模式");
}else{
printf("大端模式");
}
return 0;
}