1个字=2个字节
1个字节=8位
大小端字节序(也叫网络字节序,主机字节序):
产生原因:字节序,说明只有多字节时才会产生该问题,像字符型数组每个空间只占一个字节,自然不会产生此类问题;
短整型:每个空间占两个字节
高低位如何判断?
从左往右依次变高
如:0x12345678
0x12>0x34>0x56>0x78
地址高低如何判断?
从左往右:地址从低到高
大端字节序:低地址存高位,高地址存地位
小段字节序:高地址存低位,低地址存高位
#include<stdio.h>
union
{
short int i[2];
long int k;
char c[4];
}a,*r=&a;
int main()
{
r->i[0]=0x1234;
r->i[1]=0x5678;
int n;
for(n=0;n<2;n++)
{
printf("%x\n",&r->i[n]);
}
for(n=0;n<4;n++)
{
printf("%x\n",&r->c[n]);
}
printf("%x\n",&r->k);
for(n=0;n<2;n++)
{
printf("%x\n",r->i[n]);
}
for(n=0;n<4;n++)
{
printf("%x\n",r->c[n]);
}
printf("%x\n",r->k);
return 0;
}
因为短整型占两个字节,所以每个地址间差2
而字符型数组只占一个,且地址从上往下一次变大
一般来说,现代PC采用小端序,因此又称为主机字节序。两个字节序不同的主机之间直接传递数据必然会出错。那么解决的办法就是:发送端总是把要发送的数据转换为大端序,接受方根据自己的字节序来决定是否需要将收到的数据进行转换(小端机需要转换,大端机不需要转换)。需要注意的是,同一个主机上的两个进程之间通信,也要考虑字节序的问题(比如一个用C写的,一个用JAVA写的,JAVA虚拟机采用的是大端序)。
因为时主机字节序,所以内存里的储存形式是34 12,78 56(高位的在高地址)
然后内存里输出是由高地址往低地址输出,所以是1234 5678
但是字符型数组只占一个字节,所以输出时候是34 12 78 56
最后长整形k,占8个字节,所以由高地址往低地址输出是56781234