UPDclient server

Visual Studio 2022 中可以运行的 UDP 客户端和服务器的示例代码。这个示例使用 C++ 和 Windows Socket API 来实现 UDP 通信。

服务器端代码(udp_server.cpp

#include <iostream>
#include <winsock2.h>
#include <ws2tcpip.h>#pragma comment(lib, "Ws2_32.lib")#define DEFAULT_PORT "27015"
#define DEFAULT_BUFLEN 512int main() {WSADATA wsaData;int iResult;// 初始化 WinsockiResult = WSAStartup(MAKEWORD(2, 2), &wsaData);if (iResult != 0) {std::cout << "WSAStartup failed: " << iResult << std::endl;return 1;}struct addrinfo *result = NULL, *ptr = NULL, hints;ZeroMemory(&hints, sizeof(hints));hints.ai_family = AF_INET;hints.ai_socktype = SOCK_DGRAM;hints.ai_protocol = IPPROTO_UDP;hints.ai_flags = AI_PASSIVE;// 解析本地地址和端口iResult = getaddrinfo(NULL, DEFAULT_PORT, &hints, &result);if (iResult != 0) {std::cout << "getaddrinfo failed: " << iResult << std::endl;WSACleanup();return 1;}SOCKET ListenSocket = INVALID_SOCKET;// 创建监听套接字ListenSocket = socket(result->ai_family, result->ai_socktype, result->ai_protocol);if (ListenSocket == INVALID_SOCKET) {std::cout << "socket failed: " << WSAGetLastError() << std::endl;freeaddrinfo(result);WSACleanup();return 1;}// 绑定套接字iResult = bind(ListenSocket, result->ai_addr, (int)result->ai_addrlen);if (iResult == SOCKET_ERROR) {std::cout << "bind failed: " << WSAGetLastError() << std::endl;freeaddrinfo(result);closesocket(ListenSocket);WSACleanup();return 1;}freeaddrinfo(result);char recvbuf[DEFAULT_BUFLEN];int recvbuflen = DEFAULT_BUFLEN;struct sockaddr_in clientAddr;int clientAddrLen = sizeof(clientAddr);std::cout << "UDP Server is listening on port " << DEFAULT_PORT << std::endl;while (true) {// 接收数据iResult = recvfrom(ListenSocket, recvbuf, recvbuflen, 0, (struct sockaddr*)&clientAddr, &clientAddrLen);if (iResult > 0) {recvbuf[iResult] = '\0';std::cout << "Received from client: " << recvbuf << std::endl;// 回显数据给客户端iResult = sendto(ListenSocket, recvbuf, iResult, 0, (struct sockaddr*)&clientAddr, clientAddrLen);if (iResult == SOCKET_ERROR) {std::cout << "sendto failed: " << WSAGetLastError() << std::endl;}}else if (iResult == 0) {std::cout << "Connection closing..." << std::endl;}else {std::cout << "recvfrom failed: " << WSAGetLastError() << std::endl;}}// 关闭套接字closesocket(ListenSocket);WSACleanup();return 0;
}

客户端代码(udp_client.cpp

#include <iostream>
#include <winsock2.h>
#include <ws2tcpip.h>#pragma comment(lib, "Ws2_32.lib")#define DEFAULT_PORT "27015"
#define DEFAULT_BUFLEN 512
#define DEFAULT_SERVER_IP "127.0.0.1"int main() {WSADATA wsaData;int iResult;// 初始化 WinsockiResult = WSAStartup(MAKEWORD(2, 2), &wsaData);if (iResult != 0) {std::cout << "WSAStartup failed: " << iResult << std::endl;return 1;}struct addrinfo *result = NULL, *ptr = NULL, hints;ZeroMemory(&hints, sizeof(hints));hints.ai_family = AF_INET;hints.ai_socktype = SOCK_DGRAM;hints.ai_protocol = IPPROTO_UDP;// 解析服务器地址和端口iResult = getaddrinfo(DEFAULT_SERVER_IP, DEFAULT_PORT, &hints, &result);if (iResult != 0) {std::cout << "getaddrinfo failed: " << iResult << std::endl;WSACleanup();return 1;}SOCKET ConnectSocket = INVALID_SOCKET;// 创建套接字ConnectSocket = socket(result->ai_family, result->ai_socktype, result->ai_protocol);if (ConnectSocket == INVALID_SOCKET) {std::cout << "socket failed: " << WSAGetLastError() << std::endl;freeaddrinfo(result);WSACleanup();return 1;}char sendbuf[DEFAULT_BUFLEN];char recvbuf[DEFAULT_BUFLEN];int recvbuflen = DEFAULT_BUFLEN;std::cout << "Enter a message to send to the server: ";std::cin.getline(sendbuf, DEFAULT_BUFLEN);// 发送数据到服务器iResult = sendto(ConnectSocket, sendbuf, (int)strlen(sendbuf), 0, result->ai_addr, (int)result->ai_addrlen);if (iResult == SOCKET_ERROR) {std::cout << "sendto failed: " << WSAGetLastError() << std::endl;freeaddrinfo(result);closesocket(ConnectSocket);WSACleanup();return 1;}struct sockaddr_in serverAddr;int serverAddrLen = sizeof(serverAddr);// 接收服务器的响应iResult = recvfrom(ConnectSocket, recvbuf, recvbuflen, 0, (struct sockaddr*)&serverAddr, &serverAddrLen);if (iResult > 0) {recvbuf[iResult] = '\0';std::cout << "Received from server: " << recvbuf << std::endl;}else if (iResult == 0) {std::cout << "Connection closed by server." << std::endl;}else {std::cout << "recvfrom failed: " << WSAGetLastError() << std::endl;}// 清理资源freeaddrinfo(result);closesocket(ConnectSocket);WSACleanup();return 0;
}

代码解释

  • 服务器端

    1. 初始化 Winsock:调用 WSAStartup 函数初始化 Windows Sockets DLL。
    2. 解析地址和端口:使用 getaddrinfo 函数解析本地地址和端口。
    3. 创建和绑定套接字:使用 socket 函数创建 UDP 套接字,并使用 bind 函数将套接字绑定到指定的地址和端口。
    4. 接收和发送数据:使用 recvfrom 函数接收客户端发送的数据,并使用 sendto 函数将数据回显给客户端。
  • 客户端

    1. 初始化 Winsock:同样调用 WSAStartup 函数初始化 Windows Sockets DLL。
    2. 解析服务器地址和端口:使用 getaddrinfo 函数解析服务器的地址和端口。
    3. 创建套接字:使用 socket 函数创建 UDP 套接字。
    4. 发送和接收数据:使用 sendto 函数向服务器发送数据,并使用 recvfrom 函数接收服务器的响应。

在 VS2022 中运行步骤

  1. 打开 Visual Studio 2022,创建一个新的控制台应用程序项目。
  2. 将上述服务器端代码复制到一个 .cpp 文件中,例如 udp_server.cpp;将客户端代码复制到另一个 .cpp 文件中,例如 udp_client.cpp
  3. 分别编译和运行这两个程序。先运行服务器端程序,然后运行客户端程序,在客户端输入要发送的消息,客户端将消息发送给服务器,服务器接收到消息后将其回显给客户端。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/41210.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

LangChain开发(四)服务监控(LangSmith、verbose、debug)

文章目录 LangChain服务监控LangSmith Tracing&#xff08;跟踪&#xff09;Verbose&#xff08;1详细日志打印&#xff09;Debug&#xff08;调试日志打印&#xff09;源码地址参考资料 LangChain服务监控 与构建任何类型的软件一样&#xff0c;使用LLM构建时&#xff0c;总会…

从车间到数字生态:MES如何引领制造业智能化革命‌

在全球制造业加速迈向工业4.0的浪潮中&#xff0c;传统生产模式正经历颠覆性变革。制造执行系统&#xff08;MES&#xff09;作为连接物理车间与数字世界的核心纽带&#xff0c;正从“生产辅助工具”升级为“智能决策大脑”&#xff0c;推动制造业向数据驱动、柔性化与可持续化…

人工智能之数学基础:瑞利商的推广形式——广义瑞利商

本文重点 在数学和工程领域,瑞利商(Rayleigh quotient)的推广形式——广义瑞利商(Generalized Rayleigh quotient)扮演着重要的角色。它们不仅为线性代数中的特征值问题提供了新的视角,还在信号处理、机器学习、计算机视觉等领域有广泛的应用。 广义瑞利商的定义 广义…

【QT】QT中的中文显示乱码解决

QT中的中文显示乱码解决 1.编辑栏左键——>选择编码 2.选择UTF-8—>按编码重新载入 3.工具栏左键—>选择选项 4.同样选择UTF-8—>确定即可

优选算法系列(4.前缀和 _下) k

目录 五&#xff1a;和为 k 的子数组&#xff08;medium&#xff09; 题目链接&#xff1a;560. 和为 K 的子数组 - 力扣&#xff08;LeetCode&#xff09; 解法&#xff1a; 代码&#xff1a; 六&#xff1a;和可被 K 整除的子数组&#xff08;medium&#xff09; 题目链…

批量处理word里面表格的空白行

1&#xff0c;随便打开一个word文档。 2&#xff0c;按下Alt F11 VBA编辑器,在左侧的「工程资源管理器」窗口中找到Normal 项目,右键选择插入->模块。 弹出一下弹窗 3&#xff0c;输入一下代码 代码&#xff1a; Sub RemoveEmptyTableRows()Dim tbl As TableDim row As R…

《Linux运维实战:Ubuntu 22.04使用pam_faillock实现登录失败处理策略》

总结&#xff1a;整理不易&#xff0c;如果对你有帮助&#xff0c;可否点赞关注一下&#xff1f; 更多详细内容请参考&#xff1a;Linux运维实战总结 一、背景信息 在ubuntu 22.04中&#xff0c;pam_tally2模块已被弃用&#xff0c;取而代之的是pam_faillock模块。因此&#xf…

如何通过数据可视化提升管理效率

通过数据可视化提升管理效率的核心方法包括清晰展示关键指标、及时发现和解决问题、支持决策优化。其中&#xff0c;清晰展示关键指标尤为重要。通过数据可视化工具直观地呈现关键绩效指标&#xff08;KPI&#xff09;&#xff0c;管理者能快速、准确地理解业务现状&#xff0c…

Qt的文件操作

Qt的文件操作 由于 Qt 的发展比较早&#xff0c;在 C 尚未提供标准的文件流操作时&#xff0c;Qt 就研发出了自己的文件操作并沿用至今。Qt 提供了丰富的文件操作类&#xff0c;包括 QFile 文件操作和读写类以外&#xff0c;还有 QSaveFile&#xff08;安全文件保存类&#xf…

Netty源码—7.ByteBuf原理四

大纲 9.Netty的内存规格 10.缓存数据结构 11.命中缓存的分配流程 12.Netty里有关内存分配的重要概念 13.Page级别的内存分配 14.SubPage级别的内存分配 15.ByteBuf的回收 13.Page级别的内存分配 (1)Page级别的内存分配的入口 (2)Page级别的内存分配的流程 (3)尝试在现…

Leetcode 最小基因变化

java solution&#xff1a;BFS 算法 class Solution {public int minMutation(String startGene, String endGene, String[] bank) {//首先创建一个集合来存储有效基因串Set<String> bankSet new HashSet<>(Arrays.asList(bank));if(!bankSet.contains(endGene))…

Hive工作所遇问题之Hive -e命令中使用正则表达式问题

前言 今天工作因为之前建表时&#xff0c;看不到数据&#xff0c;导致建表的字段格式有问题&#xff0c;然后使用split函数拆分时&#xff0c;发现是正则表达式使用的问题。 下面来说明问题 一、数据准备 --创建码表&#xff1a; create table hive_sql.d_type( type_id st…

自动化框架的设计与实现

一、自动化测试框架 在大部分测试人员眼中只要沾上“框架”&#xff0c;就感觉非常神秘&#xff0c;非常遥远。大家之所以觉得复杂&#xff0c;是因为落地运用起来很复杂&#xff1b;每个公司&#xff0c;每个业务及产品线的业务流程都不一样&#xff0c;所以就导致了“自动化…

如何防止用户大量使用同一用户名恶意攻击

如何防止用户大量使用同一用户名恶意攻击&#xff1f; 在数据库层兜底 使用redisson分布式锁 当用户第一次在毫秒级别使用大量的请求去注册 由于布隆过滤器中还没没有缓存这些数据 大量请求打在数据库上可能会造成数据库宕机 因此可以使用reddison分布式锁来保证只有一个…

超详细docker部署搭建私有仓库harbor

一、安装docker 确保你的服务器上已经安装了 Docker 如果没有安装&#xff0c;按以下方法安装 yum install -y yum-utils yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo yum install docker-ce docker-ce-cli containerd.io 启动d…

541. 反转字符串 II

541. 反转字符串 IIhttps://leetcode.cn/problems/reverse-string-ii/ 给定一个字符串 s 和一个整数 k&#xff0c;从字符串开头算起&#xff0c;每计数至 2k 个字符&#xff0c;就反转这 2k 字符中的前 k 个字符。 如果剩余字符少于 k 个&#xff0c;则将剩余字符全部反转。…

力扣HOT100之普通数组:53. 最大子数组和

这道题目我用贪心做的&#xff0c;感觉用贪心的思路比较简单&#xff0c;以后要是面试碰到这道题就直接用贪心好了&#xff0c;这道题用贪心的核心思想就是不断将数组元素i加入总和sum&#xff0c;如果sum比当前维护的最大值result更大&#xff0c;说明当前遍历到的i是正数&…

muduo库的思路梳理

前言 对于muduo库源码的剖析我发现还是有些混乱的&#xff0c;所以这里再次梳理一下muduo网络库争取可以简单明了 首先对于muduo库来说&#xff0c;不能想的得太过于复杂&#xff0c;它无非就是一个线程池加上epoll组成的网络库 这里我们从用的角度出发理解muoduo网络库 #inc…

【C语言系列】数据在内存中存储

数据在内存中存储 一、整数在内存中的存储二、大小端字节序和字节序判断2.1什么是大小端&#xff1f;2.2练习2.2.1练习12.2.2练习22.2.3练习32.2.4练习42.2.5练习52.2.6练习6 三、浮点数在内存中的存储3.1练习3.2浮点数的存储3.2.1 浮点数存的过程3.2.2 浮点数取的过程 3.3题目…

C++学习之网盘项目单例模式

目录 1.知识点概述 2.单例介绍 3.单例饿汉模式 4.饿汉模式四个版本 5.单例类的使用 6.关于token的作用和存储 7.样式表使用方法 8.qss文件中选择器介绍 9.qss文件样式讲解和测试 10.qss美化登录界面补充 11.QHTTPMULTIPART类的使用 12.文件上传协议 13.文件上传协议…