对于常见的十进制来说,个、十、百、千、万、亿就是不同的权,且权的大小依次增加。
“小端”和“大端”表示多字节值的哪一端(小权端或大权端)存储在该值的起始地址。
小权端存在起始地址,即是小端字节序;大权端存在起始地址,即是大端字节序。
也可以说:
举个简单的例子,对于整形0x12345678。它在大端法和小端法的系统内中,分别如下图所示的方式存放。
网络上的数据流是字节流,对于一个多字节数值,在进行网络传输的时候,先传递哪个字节?也就是说,当接收端收到第一个字节的时候,它是将这个字节作为高位还是低位来处理呢?
当前主流网络字节序定义:网络字节序采用大端字节序。
在网络传输中,接受方收到的第一个字节被当作高位看待,这就要求发送端发送的第一个字节应当是高位。可见多字节数值在发送前,在内存中数值应该以大端法存放。
比如我们经过网络发送0x12345678这个整形,因为在X86平台中,它是以小端法存放的,在发送前需要使用系统提供的== htonl()==将其转换成大端法存放,如下图所示。
一段代码:
import sys print(sys.byteorder)
结果:
little
看来我的惠普也是x86。