socket地址API

2021-02-17 02:19

阅读:510

标签:比较   根据   自身   数据   ohs   eof   32bit   nio   har   

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

socket地址API

标签:比较   根据   自身   数据   ohs   eof   32bit   nio   har   

原文地址:http://blog.51cto.com/10725691/2067405


评论


亲,登录后才可以留言!