0
点赞
收藏
分享

微信扫一扫

xmake+xrepo自建仓库添加交叉编译工具链

东林梁 2024-06-03 阅读 8

比如下面的代码

int reuse = 1;
int ret = setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, (char*)&reuse, sizeof(reuse));
if (ret == SOCKET_ERROR)
{
       log_error("_SetReuseAddr failed, err_code=%d, fd=%d", _GetErrorCode(), fd);
}

代码解释
setsockopt 函数用于设置套接字选项。参数解释如下:

  • fd:要设置选项的套接字描述符。
  • SOL_SOCKET:选项的层次,这里表示套接字级别。
  • SO_REUSEADDR:要设置的选项,这里表示允许重用本地地址。
    (char*)&reuse:指向选项值的指针,这里传递 reuse 变量的地址。
  • sizeof(reuse):选项值的大小。
    setsockopt 成功时返回 0,失败时返回 SOCKET_ERROR。

这段代码的主要作用是设置 SO_REUSEADDR 选项,以允许在套接字处于 TIME_WAIT 状态时,其他套接字可以绑定到相同的本地地址和端口。这在服务器应用程序中特别有用,可以减少由于端口占用导致的启动失败问题。如果设置失败,代码会记录错误信息。

以下是一个完整的示例,展示如何在创建套接字后设置 SO_REUSEADDR 选项:

#include <iostream>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <unistd.h>

int main() {
    int fd = socket(AF_INET, SOCK_STREAM, 0);
    if (fd == -1) {
        perror("socket creation failed");
        return 1;
    }

    int reuse = 1;
    if (setsockopt(fd, SOL_SOCKET, SO_REUSEADDR, (char*)&reuse, sizeof(reuse)) < 0) {
        perror("setsockopt(SO_REUSEADDR) failed");
        close(fd);
        return 1;
    }

    std::cout << "SO_REUSEADDR set successfully" << std::endl;

    // 继续设置套接字的其他选项或进行绑定等操作...

    close(fd);
    return 0;
}

在这个示例中,套接字创建成功后,使用 setsockopt 设置 SO_REUSEADDR 选项,以便允许地址重用。如果 setsockopt 调用失败,程序会输出错误信息并终止。

举报

相关推荐

0 条评论