转自:http://www.blogjava.net/Todd/archive/2010/04/15/318387.html
字节序
在计算机科学领域中,字节序是指存放多字节数据的字节(byte)顺序,不同的CPU的字节序类型可能不同。最常见的两种字节序是
1)小端(Little endian): 将低位字节存储在内存的高位
2)大端(Big endian) :将高位字节存储在内存的低位
little-endian是最符合人思维的字节序,而big-endian是最直观的字节序。
例子1:在内存中双字0x01020304(DWORD)的存储方式
内存地址
4000 4001 4002 4003
LE 04 03 02 01
BE 01 02 03 04
例子2:如果我们将0x1234abcd写入到以0x0000开始的内存中,则结果为
big-endian little-endian
0x0000 0x12 0xcd
0x0001 0x23 0xab
0x0002 0xab 0x34
0x0003 0xcd 0x12
x86系列CPU都是little-endian的字节序。
2、不同的CPU上运行不同的操作系统,字节序也是不同的,参见下表。
处理器 操作系统 字节排序
Alpha 全部 Little endian
HP-PA NT Little endian
HP-PA UNIX Big endian
Intelx86 全部 Little endian <-----x86系统是小端字节序系统
Motorola680x() 全部 Big endian
MIPS NT Little endian
MIPS UNIX Big endian
PowerPC NT Little endian
PowerPC 非NT Big endian <-----PPC系统是大端字节序系统
RS/6000 UNIX Big endian
SPARC UNIX Big endian
IXP1200 ARM核心 全部 Little endian
网络字节序
网络字节顺序是TCP/IP中规定好的一种数据表示格式,它与具体的CPU类型、操作系统等无关,从而可以保证数据在不同主机之间传输时能够被正确解释。网络字节顺序采用big endian排序方式。为了便于转换,BSD socket提供了一组转换函数,在使用little endian的系统中,这些函数会把字节序进行转换;在使用big endian类型的系统中,这些函数会定义成空宏。
(s 就是short l是long h是host n是network):
htons 把unsigned short类型从主机序转换到网络序;
htonl 把unsigned long类型从主机序转换到网络序;
ntohs 把unsigned short类型从网络序转换到主机序;
ntohl 把unsigned long类型从网络序转换到主机序。