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

独立C++ asio库实现的UDP Server

以下是一个使用独立的 C++ Asio 库实现的 UDP 服务器的示例代码。这个 UDP 服务器可以监听指定端口,接收客户端发送的数据,并将接收到的数据原样返回给客户端。

#include <iostream>
#include <asio.hpp>
#include <array>class UdpServer {
public:// 构造函数,初始化服务器并开始接收数据UdpServer(asio::io_context& io_context, short port): socket_(io_context, asio::ip::udp::endpoint(asio::ip::udp::v4(), port)) {startReceive();}private:// 开始异步接收数据的方法void startReceive() {socket_.async_receive_from(asio::buffer(data_, max_length), sender_endpoint_,[this](const asio::error_code& ec, std::size_t bytes_recvd) {if (!ec && bytes_recvd > 0) {handleReceive(bytes_recvd);} else {startReceive();}});}// 处理接收到的数据的方法void handleReceive(std::size_t length) {std::cout << "Received " << length << " bytes from "<< sender_endpoint_.address().to_string() << ":"<< sender_endpoint_.port() << std::endl;std::cout << "Message: " << std::string(data_.data(), length) << std::endl;// 回显接收到的数据给客户端socket_.async_send_to(asio::buffer(data_, length), sender_endpoint_,[this](const asio::error_code& /*ec*/, std::size_t /*bytes_sent*/) {startReceive();});}asio::ip::udp::socket socket_;asio::ip::udp::endpoint sender_endpoint_;static constexpr std::size_t max_length = 1024;std::array<char, max_length> data_;
};int main() {try {// 创建 io_context 对象,用于管理异步操作asio::io_context io_context;// 创建 UDP 服务器实例,监听端口 12345UdpServer server(io_context, 12345);// 启动事件循环,处理异步操作io_context.run();} catch (const std::exception& e) {// 捕获并输出异常信息std::cerr << "Exception: " << e.what() << std::endl;}return 0;
}

代码解释

UdpServer
  1. 构造函数

    • 接收一个 asio::io_context 对象和一个端口号作为参数。
    • 创建一个 asio::ip::udp::socket 对象,并将其绑定到指定的端口(使用 asio::ip::udp::endpoint)。
    • 调用 startReceive 方法开始异步接收数据。
  2. startReceive 方法

    • 使用 socket_.async_receive_from 异步地从客户端接收数据。该方法接受一个缓冲区(asio::buffer)、一个存储发送方端点信息的 sender_endpoint_ 对象,以及一个回调函数。
    • 当有数据到达时,回调函数会被触发。如果没有错误且接收到的数据长度大于 0,则调用 handleReceive 方法处理数据;否则,继续等待下一次接收。
  3. handleReceive 方法

    • 打印接收到的数据的长度、发送方的 IP 地址和端口号。
    • 使用 socket_.async_send_to 异步地将接收到的数据原样返回给客户端。
    • 在发送完成的回调函数中,如果没有错误,继续调用 startReceive 方法等待下一次接收;如果有错误,则输出错误信息并继续等待。
main 函数
  1. 创建一个 asio::io_context 对象,它是 Asio 库的核心,用于管理异步操作的事件循环。
  2. 创建一个 UdpServer 对象,指定监听的端口为 12345
  3. 调用 io_context.run() 启动事件循环,开始处理异步操作。
  4. 使用 try-catch 块捕获并处理可能抛出的异常。

编译和运行

要编译这个程序,你可以使用以下命令(假设使用 g++ 编译器):

g++ -std=c++17 -o udp_server udp_server.cpp -lpthread

运行程序:

./udp_server

运行服务器后,它会开始监听 12345 端口,等待客户端发送数据。你可以使用网络调试工具或者编写一个 UDP 客户端程序来与这个服务器进行通信测试。

http://www.lryc.cn/news/536980.html

相关文章:

  • SQL Server STUFF 函数的用法及应用场景
  • MongoDB进阶篇-索引
  • 《机器学习数学基础》补充资料:柯西—施瓦茨不等式以及相关证明
  • VisionPro 划痕检测小练习
  • 解析 2025 工业边缘计算:三大技术风向的影响力
  • 企语企业管理系iFair(F23.2_a0)在Debian操作系统中的安装
  • 如何在Flask中处理静态文件
  • 无人机飞行试验大纲
  • C语言初阶牛客网刷题——JZ65 不用加减乘除做加法】【难度:简单】
  • git 记录
  • PyTorch Lightning Trainer介绍
  • mysql监控--慢查询
  • Conda 包管理:高效安装、更新和删除软件包
  • AcWing 798. 差分矩阵
  • 通用定时器学习记录
  • 科技之光闪耀江城:2025武汉国际半导体产业与电子技术博览会5月15日盛大开幕
  • vue开发06:前端通过webpack配置代理处理跨域问题
  • ⚡️《静电刺客的猎杀手册:芯片世界里的“千伏惊魂“》⚡️
  • 【云安全】云原生-K8S(三) 安装 Dashboard 面板
  • Spring Boot 常用依赖详解:如何选择和使用常用依赖
  • C++ 设计模式-组合模式
  • 【Spring Boot】Spring 魔法世界:Bean 作用域与生命周期的奇妙之旅
  • 移远通信边缘计算模组成功运行DeepSeek模型,以领先的工程能力加速端侧AI落地
  • Cables Finance 构建集成LST与外汇RWA永续合约的综合性DEX
  • AI大模型(DeepSeek)科研应用、论文写作、数据分析与AI绘图学习
  • 【算法工程】解决linux下Aspose.slides提示No usable version of libssl found以及强化推理模型的短板
  • 什么是HTTP和HTTPS?它们之间有什么区别?
  • 【一文读懂】TCP与UDP协议
  • 数据结构 树的存储和遍历
  • Jenkins项目CICD流程