1.port 1-65535(0保留)
2.UDP发送消息最大(65507字节)
3.ipv4
struct sockaddr//netinet/in.h { sa_family_t sa_family; char sa_data[14]; }; struct in_addr { uint32_t s_addr; }; struct sockaddr_in { sa_family_t sin_family; in_port_t sin_port; struct in_addr sin_addr; char sin_zero[8]; };
sockaddr_in只是sockaddr结构中数据详细视图,在用到sockaddr的地方都将sockaddr_in 转为sockaddr
4.inet_pton(AF_INET,const char* ip,void *dst)//arpa/inet.h
将ip地址(字符串)转为指定二进制(AF_INET),保持在第三个参数中,失败返回0(无效ip地址)/负数(错误)
5.sockaddr_in.sin_port= htons(int port) //netinet/in.h
将端口(整数)转为网络字节
6.ssize_t send(socket,void* msg,size_t msgLen,int flag)//sys/socket.h
默认行为阻塞到发送所有数据为止,flag=0为默认行为,失败返回-1
7.ssize_t recv(socket,void* buf,size_t bufLen,int flag) //sys/socket.h
recv默认阻塞到至少传输一些字符(一般为一个字符),flag= 0为默认行为,失败返回-1,返回值为0指示另一端关闭tcp链接,bufLen应加1为null做预留空间
8.int getaddrinfo(const char *hoststr,const char* servicestr,const struct addrinfo* hints,struct addrinfo **result) //netdb.h
可进行域名解析,且不需要将ip或者port转为网络字节(需要转换的整形变量),成功返回0,失败返回非0;可用来将ip或者port转为网络字节(addrinfo.ai_addr)
可用来获取本机ip,将addrinfo.ai_flag= AI_PASSIVE
9.send/sendto 区别
send()调用返回时,只知道数据已经复制进缓冲区中进行传输,数据还可能会或者不会实际地进行传输(缓冲区为重传做准备)
sendto()调用返回时,就已经把消息传递给底层信道以进行传输
10.recvfrom()
假设接收n个字节,而消息为m个字节,当n<m时,剩余的字节将被悄悄地抛弃,而不会向接收程序指示
recvfrom()标志位设MSG_PEEK可预读第一个数据块
11.字节排序
大端:从高位开始传递;小端:从低位开始传递;
网络字节:大端字节顺序;
主机字节排序可能是大端也可能是小端,两主机之间应协调好
12.setsockopt()
设置缓冲区的大小即使成功也不一定设置成功,它只是提示系统,用户所期望的值
13.
多个进程拥有同一个socket句柄,若其中一个close,其他不做任何操作则socket并不会关闭(可能是引用计数)
进程:复制父进程全部状态(内存,栈,文件/套接字描述符等)
线程:共享与父进程相同的地址空间(代码/数据)