这是小弟的一个简单的 web 服务器程序,每次我直接用 Ctrl+z 来关闭这个服务器程序时候,之后再重新开启的时候,发现浏览器已经再也打不开这个端口了,我查了一下,服务状态器处于 CLOSE_WAIT 状态, 请问代码应该怎样修改才能避免这种状况,谢谢大家
#include <stdio.h> #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <arpa/inet.h> #include <string.h> #include <unistd.h> #include <stdlib.h> int main() { int listenfd; int clientfd; int optval = 1; struct sockaddr_in server_addr; struct sockaddr_in client_addr;
if((listenfd = socket(AF_INET, SOCK_STREAM, 0)) < 0)
    return -1;
setsockopt(listenfd, SOL_SOCKET, SO_REUSEADDR, (const void *)&optval, sizeof(int));
memset(&server_addr, 0, sizeof(server_addr));
server_addr.sin_family = AF_INET;
server_addr.sin_addr.s_addr = htonl(INADDR_ANY);
server_addr.sin_port = htons(8000);
if(bind(listenfd, (struct sockaddr *)&server_addr, sizeof(server_addr)) < -1)
    return -1;
if(listen(listenfd, 1) < 0)
    return -1;
int client_size = sizeof(client_addr);
while(1)
{
    clientfd = accept(listenfd, (struct sockaddr *)&client_addr, &client_size);
    if(clientfd < 0)
        exit(1);
    write(clientfd, "web server\n", 10);
    close(clientfd);
}
exit(0);
}
|  |      1momocraft      2017-07-28 15:22:26 +08:00 如果你是指 shell 中的 ctrl-z: 你其实没有关闭这个进程,只是挂起 (SIGSTOP) 了。 | 
|  |      2aisk      2017-07-28 15:23:56 +08:00 ctrl z 只是把进程挂到后台,进程其实还在,使用 fg 命令还能恢复。 | 
|  |      3fyyz      2017-07-28 15:34:16 +08:00  1 Ctrl + C | 
|      5am241      2017-07-28 15:42:48 +08:00 via Android 相关命令 jobs, fg | 
|      6qucklay      2017-07-28 17:02:50 +08:00 via iPhone ctrl  z 进程后台停止,然后 jobs 查看几号,bg %1 放后台执行。 fg %1 切换到前台执行,ctrl c 关闭进程 | 
|      7pqee      2017-07-28 17:03:10 +08:00 第一次知道 ctrl-z。。。 | 
|  |      8yumemor      2017-07-29 00:50:37 +08:00 via iPhone lsof -i port 看看是谁占用了? |