1,小端模式:内存的低地址存数据的低位,内存的高地址存数据的高位。低低高高。 2,大端模式:内存的低位存数据的高位,内存的高地址存数据的低位。 低高高低。 int i = 0x1234567的存储形式见上图。 ubuntu 10.04下的测试用例: x86结构的计算机使用的都是小端模式。一般来说,大部分用户的操作系统(如windows,FreeBSD,linux)都 是小端模式。少部分,如MAC OS是大端模式。 -------------------------------------------------------------------------------------------- 为什么有大小端模式之分? 在C语言中除了8bit的char之外,还有16bit的short型,32bit的long型,另外,对于位数大于 8位的处理器, 例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如何将多个字节安排的 问题。因此就导致了大端存储模式和小端存储模式。---------------------------------------------------------------------------------------------二,扩展。在网络上传输数据时,由于数据传输的两端对应不同的硬件平台,采用的存储字节顺序可能不一致。因此在TCP/IP协议规定了在网络上必须采用网络字节顺序,也就是大端模式。对于char型数据只占一个字节,无所谓大端和小端。而对于非char类型数据,必须在数据发送到网络上之前将其转换成大端模式。接收网络数据时按符合接受主机的环境接收。 linux下如下两个函数可以将主机数据类型转换成网络字节顺序。 ---------------------------------------------------------------------------------------------- 三,实例。 假如现在要向网络上传输端口号。端口号16位,unsigned short类型。 unsigned int i; i = htons(80); i--------------->20480 ---------------------------------------------------------------------------------------------------
- #include <stdio.h>
- int main(void)
- {
- int a = 0x12345678;
- char *p = (char *)(&a);
- if (*p == 0x78) {
- printf("xiao duan!\n");
- } else if (*p == 0x12) {
- printf("da duan!\n");
- } else {
- printf("other!\n");
- }
- return 0;
- }
- result : xiao duan
- uint32_t htonl(uint32_t hostlong);//host to network long
- uint16_t htons(uint16_t hostshort);//host to network short