套接字地址API

  
 <代码>插座
  1 .主机字节序和网络字节序
  背景:现代CPU的累加器一次都能装载(至少)4字节(32位机器)。这4字节在* *内存中排列的顺序* *将影响到它被累加器装载成整数的值。
  小知识:字节序分为大端字节序和小端字节序。
  1.1大尾数法:一个整数的高位字节(23-31bit)存储在内存的低地址处,低位字节(0-7bit)存储在内存的高地址处。
  1.2小端字节:整数的高位字节存储在内存的高地址处,而低位字节储存在内存的低地址处
  代码如下:
  
  空白byteorder () {
  联盟{
  短的价值;
  char union_bytes [sizeof(短)];
  
  }测试;
  测试。值=https://www.yisu.com/zixun/0x0102;
  如果(测试。union_bytes[0]==1) & &(测试。union_bytes [1]==2)) {
  printf (" big endian”);
  }如果(测试。union_bytes[0]==2),和(测试。union_bytes [1]==1)) {
  printf("小");
  其他}{
  printf(“未知”);}
  }
  
  1.3现代电脑大多采用小段字节序,所以小端字节序又称为主机字节序。
  2.当格式化的数据(32位或16位)在两台不同字节序的主机之间传递就会出现问题
  2.1解决方案:发送端总是把要发送的数据转化为大端字节序在发送、接收端知道数据总是大端字节序,所以接收端可以根据自身的情况来决定是否转换(小段转换,大端字节序不转换)
  3 .大端字节序又被称为网络字节序
  4 .进程字节问题:同一台机器上的两个进程,一个是C语言,一个是JAVA语言编写,也要考虑字节序的问题(JAVA虚拟机普遍使用大端字节序)
  5. linux转换大小端字节序的函数(4个)
  5.1无符号长整数htonl(无符号长整数hostlong);
  5.2无符号短整型htons (unsigned int hostshort短);
  5.3无符号长整数ntohl(无符号长整数netlong);
  5.4无符号短整型ntohs (unsigned int netshort短);
  
  5.5上述四个含义比较明确:htonl表示主机网络长
  即将长整数型(32位)的主机字节序转换为网络字节序数据。
  5.6长整型函数通常用来转换IP地址,短整型常用来转换端口号(不限于此,所有的格式化的数据通过网络传输时,都应该使用这些函数来转换字节序) 

套接字地址API