socket可以看成是用户进程与内核网络协议栈的编程接口。进程间通信的手段!
通用地址结构是适合所有套接字编程的,后面的char sa_data[14];代表的也就是sockaddr_in(TCP/IP协议)的后面三个字段,位数相等。一般情况使用都是用前面的sockaddr_in进行绑定套接字地址然后强制转换为sockaddr结构来进行用于各种协议(unix域协议等)。
可以用过man 7 ip进行查询写法!
EOF(end of File)
socket不仅可以用于本机的进程间通信,还可以用于网络上不同主机的进程间通信。全双工。而管道只能在同一主机间进行通信!
套接口的地址结构:来标识一个端点
qIPv4套接口地址结构通常也称为“网际套接字地址结构”,它以“sockaddr_in”命名,定义在头文件<netinet/in.h>中
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];
};
qsin_len:整个sockaddr_in结构体的长度,在4.3BSD-Reno版本之前的第一个成员是sin_family.
qsin_family:指定该地址家族,在这里必须设为AF_INET
qsin_port:端口
qsin_addr:IPv4的地址;
qsin_zero:暂不使用,一般将其设置为0
q通用地址结构用来指定与套接字关联的地址
struct sockaddr {
uint8_t sin_len;
sa_family_t sin_family;
char sa_data[14];
};
qsin_len:整个sockaddr结构体的长度
qsin_family:指定该地址家族
qsa_data:由sin_family决定它的形式。
网络字节序:异构系统 不同系统间可能存放字节顺序不同 需要统一字节序为网络字节序 规定为大端字节序 不同主机有不同的字节序 ,如x86为小端字节序
大端字节序:big endian 最高有效位存储于最低内存地址处,最低有效位存储于最高内存地址处。
q小端字节序(Little Endian)
最高有效位(MSB:Most Significant Bit)存储于最高内存地址 处,最低有效位(LSB:Lowest Significant Bit)存储于最低内存地址处。
q主机字节序
不同的主机有不同的字节序,如x86为小端字节序,Motorola 6800为大端字节序,ARM字节序是可配置的。
q网络字节序
网络字节序规定为大端字节序
不同主机间字节的传递都会先转换为网络字节序 ,然后再转换为网络字节序。
uint32_t htonl(uint32_t hostlong);
uint16_t htons(uint16_t hostshort);
uint32_t ntohl(uint32_t netlong);
uint16_t ntohs(uint16_t netshort);
说明:在上述的函数中,h代表host;n代表network s代表short;l代表long
我们习惯的是点分十进制地址 192.168.0.100比较直观的ip地址 对应的32位地址是怎样的呢?所以需要引入地址转换函数:
#include <netinet/in.h>
#include <arpa/inet.h>
int inet_aton(const char *cp, struct in_addr *inp);//点分十进制的地址转换为网络字节序的地址
in_addr_t inet_addr(const char *cp);//点分十进制的地址转换为网络字节序的32位地址
char *inet_ntoa(struct in_addr in);//将地址结构转换为点分十进制格式