我有一个监听某个端口的Socket。
我向等待该端口(使用accept)的线程发送SIGSTOP信号并终止它。然后我关闭了我正在等待的Socket的文件描述符。但是在下一次运行我的项目时,它不允许我再次监听该端口。
我的程序是在Linux下用C++编写的。
我该怎么办?
我的代码的一些部分如下:
线程1:
void* accepter(void *portNo) {
int newsockfd;
sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (sockfd < 0) {
perror("ERROR opening socket");
}
struct sockaddr_in server;
bzero((char *) & server, sizeof (server));
server.sin_family = AF_INET;
server.sin_port = htons(*(int*) portNo);
server.sin_addr.s_addr = INADDR_ANY;
if (bind(sockfd, (struct sockaddr *) & server, sizeof (struct sockaddr_in)) < 0) {
perror("ERROR on binding");
}
listen(sockfd, 50);
while (true) {
struct sockaddr_in client;
socklen_t clientLen = sizeof (struct sockaddr_in);
newsockfd = accept(sockfd, (struct sockaddr *) & client, &clientLen);
if (accepterFlag) {
break;
}
if (getpeername(newsockfd, (sockaddr *) & client, &clientLen) == -1) {
perror("getpeername() failed");
}
sem_wait(setSem);
FD_SET(newsockfd, &set);
if (maxFd < newsockfd) {
maxFd = newsockfd;
}
sem_post(setSem);
}
线程2:
listenerFlag = true;
accepterFlag = true;
sleep(1);
pthread_kill(listenerThread, SIGSTOP);
pthread_kill(accepterThread, SIGSTOP);
close(sockfd);
sem_wait(setSem);
for (int i = 1; i <= maxFd; i++) {
if (FD_ISSET(i, &set)) {
close(i);
}
}
sem_post(setSem);
谢谢。
SIGSTOP
吗?之后会有人发送SIGCONT
吗?如果某个(已停止的)线程仍在该套接字上进行accept
调用,那么我不会感到惊讶,套接字可能无法最终关闭。(你说你也终止了线程,但我没有看到。) - Christopher Creutzig