struct timeval timeout = {5, 0};
rset = allset;
nready = select(maxfd + 1, &rset, NULL, NULL, &timeout);
当使用select等待客户端发送数据时,如果客户端断开了连接,无论是主动close还是程序挂掉了,这时候select都会返回1,而且通过FD_ISSET可以看到是与该客户端相连的socket触发产生的,如果此时服务端仍然调用read读取信息,会返回0。而且如果这时候不处理该socket,select会不断的返回,并且read始终返回0。所以通过select应该无法判断触发返回的原因是有数据还是对方断开了,需要调用read函数,可以判断原因。

本文探讨了使用select函数监听客户端数据时如何区分客户端正常断开连接与有新数据到达的情况。文中指出,在客户端断开连接后,select会返回1,并且可以通过FD_ISSET检查到是哪个socket触发了事件。然而,若直接调用read则会返回0,说明无法通过select直接判断客户端是否真正断开。文章最后强调需要调用read函数进一步确认是数据到达还是连接断开。

788

被折叠的 条评论
为什么被折叠?



