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地址,短整型常用来转换端口号(不限于此,所有的格式化的数据通过网络传输时,都应该使用这些函数来转换字节序)