C++ 中断接收插座
我有一个WinSockC++ 中断接收插座,c++,sockets,timeout,winsock,C++,Sockets,Timeout,Winsock,我有一个WinSockmySocket,它以如下方式循环接收: while(keepGoing){ FD_SET fsd; FD_ZERO(&fds); FD_SET(mySocket, &fds); int result = select(1+mySocket, &fds, (fd_set *)0, (fd_set *)0, &timeout); if(result>0 && FD_ISSET(my
mySocket
,它以如下方式循环接收:
while(keepGoing){
FD_SET fsd;
FD_ZERO(&fds);
FD_SET(mySocket, &fds);
int result = select(1+mySocket, &fds, (fd_set *)0, (fd_set *)0, &timeout);
if(result>0 && FD_ISSET(mySocket, &fds){
result = recvfrom(mySocket, buff, NUM_BYTES, (struct sockaddr *)&add, &length);
// do stuff
}
}
如果我想停止接收,我可以将keepGoing
设置为false,但套接字可能仍在等待timeout
,然后才发现keepGoing
已更改
假设我们不想更改超时值,是否有可靠的方法告诉套接字停止接收而不等待超时发生?当
errno
为EINTR
时,您可以发出良性信号并检查keepGoing
标志。或者,您可以创建管道
,并将读取端添加到选择集。设置keepGoing
标志后关闭写入端
int quitfds[2];
pipe(quitfds);
//...
FD_SET(quitfds[0], &fds);
//...
if (FD_ISSET(quitfds[0], &fds)) {
close(quitfds[0]);
continue;
}
Edit:Adam指出我错过了问题中的Winsock
参考。您可以使用socketpair
而不是管道
。它似乎没有在Windows上实现,但我发现。Ben指出,WSAEventSelect
允许混合不同的事件对象。多亏了这两种方法。这对Unix很好,但Windows没有信号,WinSock的select
实现只能处理套接字对象,而不能处理其他类型的类似文件的对象,如管道。@Adam:True ofselect
,但是Windows也有WSAEventSelect
,它确实支持混音。@亚当:谢谢你向我指出,我在问题中遗漏了这一点。@Ben:哦,好的,我不知道WSAEventSelect
。如果是TCP,你已经完全完成了套接字,请关闭它进行输入。这将向recv()
方法(返回值为零)提供流的结束。您仍然可以写入套接字。