当前位置: 首页 > article >正文

Socket网络编程之UDP套件字

基于的UDP套件字编程流程

UDP传输层的协议,面向无连接,数据报的传输层协议。
“ 无连接 ”:不可靠

  • 在网络环境较好的情况下,UDP效率较高
  • 在网络环境较差的情况下,UDP可能存在丢包的情况
  • 同时一些“ 实时应用 ” 采用UDP
  • 在应用层加一些保证传输可靠的“1

UCP网络应用

  • Recver 接收端(TCP
  • Sender 发送端(TCP

UDP网络应用的编程流程

UDP Sender(接收端)
创建一个套接字

同样使用socket接口申请一个套接字

  • SOCK_DGRAM 类型的套接字

绑定网络地址
同样使用bind接口将一个套接字和一个网络地址进行绑定

数据通信

  • 接收

    • RECV(2)                                                                 Linux Programmer's Manual                                             RECV(2)NAMErecv, recvfrom, recvmsg - receive a message from a socketSYNOPSIS#include <sys/types.h>#include <sys/socket.h>ssize_t recvfrom(int sockfd, void *buf, size_t len, int 
      flags,struct sockaddr *src_addr, socklen_t *addrlen);/*@描述:从一个套接字中接收数据@sockfd:接收数据的套接字@buf:接收到的数据所存放的位置/空间@len:接收数据的空间有多大@flags:标志位:一般为0@src_addr:指向网络地址信息的结构体空间,用来存储发送者信息的结构体,可以为
      NULL,表示不关系发送者信息@addrlen:指向网络地址信息结构体的空间大小的指针@return:成功返回实际读取字节数失败返回-1*/
      

关闭套接字

UDP Client(发送端)

创建一个套接字
同样使用socket接口申请一个套接字

  • SOCK_DGRAM 类型的套接字

数据通信

  • 发送
SEND(2)                                                                 Linux Programmer's Manual                                               SEND(2)NAMEsend, sendto, sendmsg - send a message on a socketSYNOPSIS#include <sys/types.h>#include <sys/socket.h>ssize_t sendto(int sockfd, const void *buf, size_t len, int 
flags,const struct sockaddr *dest_addr, socklen_t addrlen);/*@描述:通过一个合法套接字往一个指定的地址发送一条消息@sockfd:网络套接字@buf:需要发送的内容指针@len:需要发送的内容长度@flags:标志位:一般采用0@dest_addr:目标地址,接收方的网络地址@addrlen:目标网络地址结构体的大小@return:成功返回实际发送的字节数失败返回-1*/

关闭套接字

示例

接收端

#include <iostream>
#include <sys/socket.h>
#include <sys/types.h>
#include <cstring>
#include <arpa/inet.h>#include <unistd.h>
using namespace std;
// UDP编程客户端int main()
{// 创建一个套接字int socket_udpid = socket(AF_INET, SOCK_DGRAM, 0);if(socket_udpid == -1){perror("创建套接字失败");return -1;}cout << " 套接字创建成功" << endl;// 绑定一个网络地址:(bind)struct sockaddr_in addr;// 指定为IPV4addr.sin_family = AF_INET;addr.sin_port = htons(8989); //指端口addr.sin_addr.s_addr = inet_addr("192.168.5.128");// sizeof(addr) 返回的值会被隐式转换为 socklen_t 类型。if((bind(socket_udpid, (const struct sockaddr* )&addr, sizeof(addr))) == -1){perror("绑定失败");return -1;}cout << "绑定成功" << endl;// 通信while(1){// 接收数据char buf[1024] = {0};struct sockaddr_in  sendInfor;socklen_t len = sizeof(sendInfor);if(recvfrom(socket_udpid, buf, 1024 , 0 ,(struct sockaddr*) &sendInfor, &len) == -1){perror("接收数据失败");return -1;}if(strcmp(buf, "exit") == 0){cout << "结束通信" << endl;break;}cout << "接收到的数据是:" << buf << endl;}// 关闭套接字close(socket_udpid);return 0;
}

发送端

#include <winsock2.h>
#include <windows.h>
#include <iostream>
using namespace std;
int main()
{// 初始化网络库WSADATA wsData;WSAStartup(MAKEWORD(2,2) ,&wsData);// 创建套接字SOCKET socket_udpid = socket(AF_INET, SOCK_DGRAM, 0);if(socket_udpid == INVALID_SOCKET){cerr <<  "连接失败,错误码:" << WSAGetLastError() << endl;WSACleanup();return -1;}// 设置接收端的地址struct sockaddr_in addr;addr.sin_family = AF_INET;addr.sin_port = htons(8989);addr.sin_addr.s_addr = inet_addr("192.168.5.128");int addlen = sizeof(addr);while(1){//发送信息char senfbuf[1024] = {0};cout << "请输入";cin >> senfbuf;sendto(socket_udpid, senfbuf, sizeof(senfbuf), 0,(const sockaddr*)&addr, addlen );if(strcmp(senfbuf, "exit") == 0){cout << "结束通信" << endl;break;}}//关闭套接字
closesocket(socket_udpid);
return 0;
}
http://www.lryc.cn/news/2395698.html

相关文章:

  • 前端学习(7)—— HTML + CSS实现博客系统页面
  • Bert和GPT区别
  • 聊一聊接口测试中缓存处理策略
  • RuoYi前后端分离框架实现前后端数据传输加密(二)之前端篇
  • 如何使用.Net Reactor 批量加密 DLL
  • 基于视觉的车道线检测完整代码:让驾驶更安全的开源解决方案
  • Intellij IDEA 查找接口实现类的快捷键
  • 鸿蒙仓颉开发语言实战教程:自定义tabbar
  • 03.MySQL表的操作详解
  • 28 C 语言作用域详解:作用域特性(全局、局部、块级)、应用场景、注意事项
  • MySQL 事务解析
  • 题海拾贝:压缩字符串
  • 【Hive 运维实战】一键管理 Hive 服务:Metastore 与 HiveServer2 控制脚本开发与实践
  • 振动力学的三类基本问题
  • 04.MySQL数据类型详解
  • 移动端 UI自动化测试学习之Appium框架(包含adb调试工具介绍)
  • CS144 - Lecture 2
  • B站视频下载器 v1.0.4|免登录下载1080P视频
  • AIGC学习笔记(8)——AI大模型开发工程师
  • [蓝桥杯]剪格子
  • 明远智睿SSD2351开发板:语音机器人领域的变革力量
  • Mybtais框架各配置文件主要内容详解(一)
  • Co-IP—验证蛋白互作的不二之选
  • 数据可视化(第4、5、6次课)
  • DAY 18 推断聚类后簇的类型
  • 结合源码分析Redis的内存回收和内存淘汰机制,LRU和LFU是如何进行计算的?
  • ESG体系
  • 基于 KubeKey 3.1.9,快速部署 K8s 1.33.0 高可用集群
  • 华为深度学习面试手撕题:手写nn.Conv2d()函数
  • 归一化相关