我正在开发一个与C中的网络编程相关的小项目。我正在尝试制作一个简单的群聊项目,其中多个客户端同时连接到单个服务器,并且每当任何客户端写入消息时,服务器将向所有其他客户发送消息。
简而言之,它是一个群聊,其中连接到服务器的所有客户端都可以相互通信。但是,我有一个奇怪的问题,我无法弄清楚。
我正在做的是:运行服务器 - >运行客户端1 - >运行客户端2 - >运行客户端3 - >现在,当客户端1键入消息时,没有其他客户端收到该消息 - >当客户端2键入消息时,只有客户端1接收该消息 - >当客户端3键入消息时,客户端1和客户端3都输入消息。客户端2收到该消息。
出于某种奇怪的原因,它的工作方式是客户端的消息只会发送给在此客户端之前连接到服务器的客户端。客户3在1&之后连接2,1& 2收到第三个客户的消息,但是第三个客户没有得到第二个客户的任何消息。
以下是我在server.c文件中使用的代码:
comm_fd = accept(listen_fd, (struct sockaddr*) NULL, NULL);
arr[count++] = comm_fd;
printf("Client %d connected to the server!\n",comm_fd);
if ( (childpid = fork ()) == 0 ) { /*0 means child process*/
do {
read(comm_fd,recvline,100);
printf("Client %d: %s",comm_fd,recvline);
if(strcmp(sendline,"bye\n") == 0) {
printf("Client %d left the chat!\n",comm_fd);
close(comm_fd);
exit(4);
}
for(int i=0; i<count; i++){
if(arr[i]!=comm_fd) {
write(arr[i],recvline,strlen(recvline)+1);
}
}
} while(1);
}
这是我的client.c:
fgets(sendline,100,stdin);
write(sockfd,sendline,strlen(sendline)+1);
if(strcmp(sendline,"bye\n") == 0) {
printf("Closing connection!\n");
exit(4);
}
bzero( sendline, 100);
if ( (childpid = fork ()) == 0 ) {
do{
read(sockfd,recvline,100);
printf("%s",recvline);
if(strcmp(recvline,"bye\n") == 0) {
printf("\nA client left the chat group!\n\n");
exit(4);
}
bzero( recvline, 100);
} while(1);
}
任何人都可以帮我吗?我经常搜索这个问题的解决方案,但找不到答案。我是套接字编程的新手,所以我真的需要帮助。提前谢谢!
答案 0 :(得分:3)
出于一些奇怪的原因,它以一种消息的方式工作 客户端将仅发送给连接到服务器的客户端 在此客户之前
这种行为对我有意义 - fork()创建一个子进程,其内存/状态是父进程当前状态的副本,这意味着对父进程的任何更改(例如接受一个fork()调用之后发生的新客户端连接将不会传播到现有子进程。因此,每个子进程只会“看到”通过fork()创建自己的子进程时已连接的客户端。