socket 1.主机字节序和网络字节序 背景:现代CPU的累加器一次都能装载(至少)4字节(32位机器)。这4字节在**内存中排列的顺序**将影响到它被累加器装载成整数的值。 小知识:字节序分为大端字节序和小端字节序。 1.1big endian:一个整数的高位字节(23-31bit)存储在内存的低地址处,低位字节(0-7bit)存储在内存的高地址处。 1.2little endian:整数的高位字节存储在内存的高地址处,而低位字节储存在内存的低地址处 代码以下: 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"); }else if( (test.union_bytes[0] == 2)&&(test.union_bytes[1] == 1)){ printf("ittle "); }else{ printf("unknown");} } 1.3现代PC大多采用小段字节序,因此小端字节序又称为主机字节序。 2.当格式化的数据(32bit or 16bit)在两台不一样字节序的主机之间传递就会出现问题 2.1解决方案:发送端老是把要发送的数据转化为大端字节序在发送,接收端知道数据老是大端字节序,因此接收端能够根据自身的状况来决定是否转换(小段转换,大端字节序不转换) 3.大端字节序又被称为网络字节序 4.进程字节问题:同一台机器上的两个进程,一个是C语言,一个是JAVA语言编写,也要考虑字节序的问题(JAVA虚拟机广泛使用大端字节序) 5.linux转换大小端字节序的函数(4个) 5.1 unsigned long int htonl(unsigned long int hostlong); 5.2 unsigned short int htons(unsigned short int hostshort); 5.3 unsigned long int ntohl(unsigned long int netlong); 5.4 unsigned short int ntohs(unsigned short int netshort); 5.5上述四个含义比较明确:htonl表示host to network long 即将长整数型(32bit)的主机字节序转换为网络字节序数据。 5.6长整型函数一般用来转换IP地址,短整型经常使用来转换端口号(不限于此,全部的格式化的数据经过网络传输时,都应该使用这些函数来转换字节序)