一段c++代码,多线程通讯完成可以连续监听目标端口的通讯

#include <iostream>
#include <string>
#include <thread>
#include <chrono>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <unistd.h>
#include <fcntl.h>
#include <cstring>

// UDP监听函数
void UDPListen(const std::string& targetIP, int targetPort) {
    // 创建UDP套接字
    int sockfd = socket(AF_INET, SOCK_DGRAM, 0);
    if (sockfd == -1) {
        std::cout << "Failed to create socket." << std::endl;
        return;
    }

    // 设置套接字为非阻塞模式
    int flags = fcntl(sockfd, F_GETFL, 0);
    fcntl(sockfd, F_SETFL, flags | O_NONBLOCK);

    // 设置目标地址和端口
    sockaddr_in targetAddr;
    std::memset(&targetAddr, 0, sizeof(targetAddr));
    targetAddr.sin_family = AF_INET;
    targetAddr.sin_port = htons(targetPort);
    if (inet_pton(AF_INET, targetIP.c_str(), &(targetAddr.sin_addr)) <= 0) {
        std::cout << "Invalid target IP address." << std::endl;
        close(sockfd);
        return;
    }

    // 绑定本地地址和端口
    sockaddr_in localAddr;
    std::memset(&localAddr, 0, sizeof(localAddr));
    localAddr.sin_family = AF_INET;
    localAddr.sin_port = htons(targetPort); // 可以根据实际需求选择本地端口
    localAddr.sin_addr.s_addr = INADDR_ANY;
    if (bind(sockfd, (const sockaddr*)&localAddr, sizeof(localAddr)) == -1) {
        std::cout << "Failed to bind socket." << std::endl;
        close(sockfd);
        return;
    }

    // 监听和接收数据
    char buffer[1024];
    while (true) {
        std::memset(buffer, 0, sizeof(buffer));

        // 接收数据
        ssize_t bytesRead = recvfrom(sockfd, buffer, sizeof(buffer) - 1, 0, NULL, NULL);
        if (bytesRead > 0) {
            // 打印接收到的数据
            std::cout << "Received: " << buffer << std::endl;
        }

        // 检测网络连接状态
        int error = 0;
        socklen_t len = sizeof(error);
        if (getsockopt(sockfd, SOL_SOCKET, SO_ERROR, &error, &len) != 0) {
            std::cout << "Failed to get socket option." << std::endl;
            close(sockfd);
            return;
        }

        // 检查网络连接状态
        bool networkConnected = (error == 0);

        // 如果网络断开,等待网络恢复
        while (!networkConnected) {
            // 打印等待网络恢复的提示信息
            std::cout << "Network disconnected. Waiting for network recovery..." << std::endl;

            // 等待一段时间后重新检测网络连接状态
            std::this_thread::sleep_for(std::chrono::seconds(5));

            // 检测网络连接状态
            if (getsockopt(sockfd, SOL_SOCKET, SO_ERROR, &error, &len) != 0) {
                std::cout << "Failed to get socket option." << std::endl;
                close(sockfd);
                return;
            }

            // 检查网络连接状态
            networkConnected = (error == 0);
        }
    }

    // 关闭套接字
    close(sockfd);
}

// 主函数
int main() {
    std::string targetIP = "192.168.1.3";
    int targetPort = 56100;

    // 创建监听线程
    std::thread listenThread(UDPListen, targetIP, targetPort);

    // 等待监听线程结束(这个例子中,永远不会结束)
    listenThread.join();

    return 0;
}

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值