最近在看《linux高性能服务器编程》,在此做个日记,以激励自己,同时分享于有需要的朋友。
现代CPU的累加器一次能装载至少4字节(32位),即一个整数。那么这4字节在内存中排列的顺序将影响它被累加器装载成的整数值,这就是字节序问题。
字节序分大端字节序(big endian)和小端字节序(little endian),大端字字节序是指一个整数的高位字节(23~31bit)存储在内存的低地址外,低位字节(0~7bit)存储在内存的高地址处。 小端字节序则是指整数的高位字节存储在内存的高地址处,而低位字节存储在内存的低地址处。
现代PC大多采用小端字节序,因此小端字节序又被称为主机字节序。
当格化数的数据在两台使用不同字节序的主机之间直接传递时,接收端必然错误解释之。解决方法是:发送端总是把要发送的数据转化成大端字节序数据后再发送,而接收端知道对方传送过来的数据总是采用大端字节序,所以接收端可以根据自身采用的字节序决定是否对接收到的数据时行转换。
因此,大端字节序也称为网络字节序,它给所有接收数据的主机提供了一个正确解释收到的格式化数据的保证。
//用于检查机器字节序的代码:
#include <stdio.h>
void byteorder()
{
union
{
short value;
char union_bytes[ sizeof( short ) ];
} test;
test.value = 0x0102;
if ( ( test.union_bytes[ 0 ] == 1 ) && ( test.union_bytes[ 1 ] == 2 ) )
{
printf( "big endian\n" );
}
else if ( ( test.union_bytes[ 0 ] == 2 ) && ( test.union_bytes[ 1 ] == 1 ) )
{
printf( "little endian\n" );
}
else
{
printf( "unknown...\n" );
}
}
int main(int argc, char **argv)
{
byteorder();
return 0;
}