UNP——第三章,套接字编程介绍

1.套接字结构

  多数套接字函数都有套接字结构参数,每个协议族都定义了自己的套接字结构,以 sockaddr_ 开始,并对应协议族的唯一后缀。

struct sockaddr_in {
    uint8_t              sin_len;
    sa_family_t          sin_family;   
    in_port_t            sin_port;
    struct in_addr       sin_addr;
    char                 sin_zero[8];  
}

  对应用层编程而言,重要的只有:

     sin_family, sin_addr, sin_port

 

2.字节序

  网络字节序为大端,即先存储数据高位。

  小端,则为 先存储数据地位。

  可以如下判断主机字节序:

union {
    short a;
    char  b[sizeof(short)];
}c;
c.b = 0x0102
if (c.b[0] == 2 && c.b[1] == 1) { printf("小端\n"); } else if (c.b[0] == 1 && c.b[1] == 2) { printf("大端\n"); } else { printf("未知\n") }

  对于大小端转换函数,推荐 inet_pton, inet_ntop

  不推荐 inet_aton, inet_ntoa,因为不支持 IPv6

 

3.封装api

  为了兼容多种情况(如IPv4和IPv6的移植),可以进行如下封装:

char *
sock_ntop(const struct sockaddr *sa, socklen_t salen)
{
       switch(sa->sa_family) {
          case AF_INET:
              .....
           beak;
          ....    
       }
}

  套接字的读写不同于一般文件读写,套接字读写,即使返回值未达到预期,也不一定错误,因为可能是缓冲区满了,就需要将剩下的数据继续操作。

  类似的,其他缓冲区(如管道)读写也是这样。

  所以需要封装 readn, writen 等函数。

  具体实现可下载unp代码:http://www.unpbook.com/

posted on 2020-01-20 22:01  开心种树  阅读(212)  评论(0编辑  收藏  举报