商城首页欢迎来到中国正版软件门户

您的位置:首页 >CentOS C++如何进行网络通信

CentOS C++如何进行网络通信

  发布于2026-05-01 阅读(0)

扫一扫,手机访问

在CentOS上实现C++网络通信的几种主流方案

CentOS C++如何进行网络通信

在CentOS环境下进行C++网络编程,开发者手头其实有不少成熟的工具和库可供选择。具体采用哪种方案,往往取决于项目的协议需求、性能考量以及对跨平台支持的要求。下面就来梳理几种最常用的方法。

1. BSD Sockets API:经典且直接

BSD Sockets堪称是UNIX及类UNIX系统(CentOS自然包含在内)网络编程的基石。这套标准接口提供了一系列C库函数,例如 socket(), bind(), listen(), accept(), connect(), send(), recv() 等,足以应对大多数底层网络通信任务。

话说回来,理解其工作原理最好的方式就是看代码。这里有一个简单的TCP服务器与客户端示例:

TCP服务器端代码:

#include 
#include 
#include 
#include 
#include 

int main() {
    int server_fd, new_socket;
    struct sockaddr_in address;
    int opt = 1;
    int addrlen = sizeof(address);
    char buffer[1024] = {0};

    // 创建socket文件描述符
    if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0) {
        perror("socket failed");
        exit(EXIT_FAILURE);
    }

    // 强制将socket绑定到8080端口
    if (setsockopt(server_fd, SOL_SOCKET, SO_REUSEADDR | SO_REUSEPORT, &opt, sizeof(opt))) {
        perror("setsockopt");
        exit(EXIT_FAILURE);
    }

    address.sin_family = AF_INET;
    address.sin_addr.s_addr = INADDR_ANY;
    address.sin_port = htons(8080);

    // 绑定socket到指定地址和端口
    if (bind(server_fd, (struct sockaddr *)&address, sizeof(address)) < 0) {
        perror("bind failed");
        exit(EXIT_FAILURE);
    }

    if (listen(server_fd, 3) < 0) {
        perror("listen");
        exit(EXIT_FAILURE);
    }

    if ((new_socket = accept(server_fd, (struct sockaddr *)&address, (socklen_t*)&addrlen)) < 0) {
        perror("accept");
        exit(EXIT_FAILURE);
    }

    read(new_socket, buffer, 1024);
    std::cout << buffer << std::endl;
    send(new_socket, "Hello from server", 17, 0);
    std::cout << "Hello message sent\n";

    close(new_socket);
    close(server_fd);
    return 0;
}

TCP客户端代码:

#include 
#include 
#include 
#include 

int main() {
    struct sockaddr_in serv_addr;
    int sock = 0;
    char buffer[1024] = {0};

    if ((sock = socket(AF_INET, SOCK_STREAM, 0)) < 0) {
        std::cout << "\n Socket creation error \n";
        return -1;
    }

    serv_addr.sin_family = AF_INET;
    serv_addr.sin_port = htons(8080);

    // 将文本格式的IP地址转换为二进制形式
    if(inet_pton(AF_INET, "127.0.0.1", &serv_addr.sin_addr) <= 0) {
        std::cout << "\nInvalid address/ Address not supported \n";
        return -1;
    }

    if (connect(sock, (struct sockaddr *)&serv_addr, sizeof(serv_addr)) < 0) {
        std::cout << "\nConnection Failed \n";
        return -1;
    }

    send(sock, "Hello from client", 17, 0);
    std::cout << "Hello message sent\n";
    read(sock, buffer, 1024);
    std::cout << buffer << std::endl;

    close(sock);
    return 0;
}

2. libcurl:处理应用层协议的利器

如果需要频繁与HTTP、HTTPS、FTP等应用层协议打交道,那么libcurl几乎是不二之选。这个极其流行的库封装了复杂的协议细节,提供了一个相对简洁的API来发送请求和接收数据,能省去大量重复造轮子的工作。

3. Boost.Asio:强大而现代的C++抽象

Boost.Asio是一个跨平台的C++库,专为网络和底层I/O编程设计。它的强大之处在于同时提供了同步和异步操作模型,并且其设计非常现代,符合C++的惯用法。除了网络,它还能处理串口通信、定时器等多种I/O服务,适合构建需要高性能或复杂并发模型的应用。

4. Qt Network Module:Qt开发者的高效选择

如果你的项目本身基于Qt框架,那么直接使用其内置的网络模块会是最高效的路径。Qt Network提供了高级的抽象,轻松实现HTTP请求、TCP/UDP通信等功能,并且与Qt的信号槽机制无缝集成,简化了事件驱动的网络编程。

5. C++ REST SDK (Casablanca):面向服务的现代库

这是由微软开发的一个库,主要用于构建基于HTTP的应用程序和服务(如RESTful API客户端/服务器)。它原生支持异步操作,并内置了JSON处理等现代Web开发中常用的功能,适合专注于服务间通信的C++项目。

如何选择?

简单来说,如果任务基础且希望保持轻量、零外部依赖,标准的BSD Sockets API是最稳妥的起点。而当你需要更高级的功能、更好的抽象层次,或者特定的协议支持时,像Boost.Asio、libcurl这样的第三方库就能显著提升开发效率。关键在于明确需求,然后选择最适合当前场景的那把“利器”。

本文转载于:https://www.yisu.com/ask/31254139.html 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。

热门关注