大端big endian 小端little endian
网络字节序为大端
对于比特串0x 12 34 56 78
低——内存地址——高
12 34 56 78 大端
78 56 34 12 小端
大端为所见即所得
小端为所见非所得 (Intel)
移位等操作是对“所得”进行
图示:
----------------------- 最低内存地址 0x00000000
正文段(代码段)
-----------------------
初始化的数据
----------------------- 统称数据段
未初始 化的数据
-----------------------
堆
-----------------------
NULL (空洞)
-----------------------
栈顶
栈
栈底
----------------------- 最高内存地址 0xffffffff
Big-Endian: 低地址存放高位,如下图:
栈顶 (低地址)
---------------
buf[0] (0x12) -- 高位
buf[1] (0x34)
buf[2] (0x56)
buf[3] (0x78) -- 低位
---------------
栈底 (高地址)
Little-Endian: 低地址存放低位,如下图:
栈 顶 (低地址)
--------------
buf[0] (0x78) -- 低位
buf[1] (0x56)
buf[2] (0x34)
buf[3] (0x12) -- 高位
---------------
栈底 (高地址)
两类型可由ntohs、ntohl系列函数转化