提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
前言
提示:以下是本篇文章正文内容,下面案例可供参考
一、UDP
概念:UDP:用户数据报一般应用于语音或者视频
数据在收发时次数必须一直。
1.特性
无连接():每次发送数据的链路是确定了,有点网络使用率较低
不可靠() :会造成丢包1.不清楚该网络节点的承受状态,如果超过就会把数据无情丢失,2.发送端发的太快,接收方没有及时处理。会导致数据的丢失。
大数据():包和包之间是有间隔。
2.编程步骤
服务端;
1.创建套接字
2.绑定套接字
3.循环{收发}
4.关闭套接字
客户端:
1.创建套接字
2.循环{收发}
3.关闭套接字
3.函数接口
服务端;
1.创建套接字
int socket(int domain, int type, int protocol);
功能:
创建用于交流的套接字文件
参数:
domain:ip协议是IPV4还是ipv6
type:是用
TCP:SOCK_STREAM
UDP:SOCK_DGRAM
protocol
返回值:
成功返回0
失败返回-1
2.绑定套接字
int bind(int sockfd, const struct sockaddr *addr,
socklen_t addrlen);
功能:将地址绑定在套接字文件上
参数:
sockfd:套接字
const struct sockaddr *addr:地址变量结构体,因为网络设备均为大端,需要将端口号和IP转换为大端,
struct sockaddr 通用地址结构
{
u_short sa_family; 地址族
char sa_data[14]; 地址信息
};
在man 7 ip中查网络地址结构
转换成网络地址结构如下:
struct _sockaddr_in ///网络地址结构
{
u_short sin_family; 地址族
u_short sin_port; ///地址端口
struct in_addr sin_addr; ///地址IP
char sin_zero[8]; 占位
};
端口小端转大端:
uint16_t htons(uint16_t hostshort);
端口大端转小端:
uint16_t ntohs(uint16_t netshort);
主机转网络:ip小端转大端:
网络转主机:
in_addr_t inet_addr(const char *cp);
网络转主机:ip大端转小端:
char *inet_ntoa(struct in_addr in);
addrlen:地址的大小
返回值:
成功返回0
失败返回-1
3.循环{收发}
收:recvfrom
ssize_t recvfrom(int sockfd, void *buf, size_t len, int flags,
struct sockaddr *src_addr, socklen_t *addrlen);
功能:接收套接字上的数据
参数:
sockfd:接收的套接字
buf:数据通过buf传递过来
len:buf的大小
flags:传递的方式一般用0就可以
src_addr:接收对方的网络结构体
addrlen:网络结构体的大小
返回值:
成功返回0
失败返回-1vi
发送:
ssize_t sendto(int sockfd, const void *buf, size_t len, int flags,const struct sockaddr *dest_addr, socklen_t addrlen);
功能:向套接字发送数据
sockfd:接收的套接字
buf:数据通过buf传递过来
len:buf的大小
flags:传递的方式一般用0就可以
src_addr:接收对方的网络结构体
addrlen:网络结构体的大小
返回值:
4.关闭套接字
int close(int fd);
客户端:与服务端相同,不重复描述。
1.创建套接字
2.循环{收发}
3.关闭套接字