gpt4 book ai didi

c - 当我只想接收单个连接时,应该如何在 C 中实现非阻塞服务器行为?

转载 作者:行者123 更新时间:2023-11-30 15:53:58 25 4
gpt4 key购买 nike

在 C 语言中,假设我有一个服务器应用程序。套接字已正确设置并已绑定(bind)到本地端口,并且调用listen()函数没有错误。

代码如下:

    //obtain a connection.
int connection;
struct sockaddr_storage sender;
socklen_t addr_size = sizeof(sender);
if((connection=accept(sockfd, (struct sockaddr*)&sender, &addr_size))==-1)
{close(sockfd); return -1; }
if(close(sockfd)==-1){
close(connection);
return -1;
}
else
return connection;

成功获取连接文件描述符,通过该描述符可以从客户端读取数据。

我的应用程序要求服务器等待有限的时间,然后在没有建立连接的情况下继续执行其他操作。此外,最多将接受一个连接。 Accept() 是一个阻塞系统调用,但我想避免阻塞。

似乎有很多不同的方法可以解决这个问题:

  • A SE question建议使用 select 来解决这个问题,但 select 是为同时监视多个文件句柄而设计的,在这里似乎有点矫枉过正。

  • 另一个question建议将套接字修改为非阻塞,然后循环检查是否已建立连接。这也可以,但看起来不太好,因为我确实想阻止 - 只是不是永远。

  • 在其他语言中,我似乎人们使用 SIGALARM 和 Alarm() 命令来防止阻塞,但我的应用程序有多个线程,这似乎是一个容易出错的解决方案。

  • 在其他一些语言(Java?)中,我认为可以将超时参数传递给accept来完成此操作。这在这里是理想的,但我似乎无法在 C 中找到类似的套接字函数。

有更好的方法来解决这个问题吗?这似乎是其他人已经想出来的事情。如果没有更好的方法,上面提到的哪种解决方案最合适?我倾向于使套接字成为非阻塞的,但它似乎引入了大量额外的麻烦。

最佳答案

使用 select 时,请记住始终使用 fcntl() 使文件描述符非阻塞,否则客户端可能会发起连接,select 将返回,客户端可能会终止,并且您的服务器将在accept() 中永远被阻塞。

成功接受后,如果您的程序以这种方式工作,您可能会再次将文件描述符转为阻塞模式。

关于c - 当我只想接收单个连接时,应该如何在 C 中实现非阻塞服务器行为?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13403105/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com