我创建了一个包含客户端和服务器的聊天室,一切正常。但我有打印问题。问题是客户端可以编写他的消息并同时从其他客户端读取消息。所以我用一个线程同时做两个。它可以工作,但看一下示例问题是什么:
在这里,我开始写我的第一个混乱,这是收到的消息,打断了我的写作,在这里我继续写作
我不知道它是否清楚:我开始写一条消息,但我还没有发送消息,因为它没有结束但是同时收到一条消息所以它会在我写作信息开始之后和我可以继续写作之后打印出来。
您是否知道如何解决问题?
以下是客户端代码:
void getMessage(char* message) {
size_t ln = -1;
while (ln <= 0 || ln > MESSAGE_MAX-1) {
printf(">");
fgets(message, MESSAGE_MAX, stdin);
ln = strlen(message) - 1;
}
if (message[ln] == '\n')
message[ln] = '\0';
}
void *thread_message(void *arg)
{
char* message;
message = malloc (sizeof(char) * MESSAGE_MAX);
int* sockfd = (int*)arg;
while (1) {
getMessage(message);
if (send(*sockfd, message, strlen(message), 0) == -1){
perror("Client: send message");
}
}
pthread_exit(NULL);
}
int main(int argc, char *argv[])
{
int sockfd, numbytes;
struct sockaddr_in their_addr;
// connector's address information
struct hostent *he;
char buf[MESSAGE_MAX + PSEUDO_MAX];
// ...
}
while (1) {
if ((numbytes=recv(sockfd, buf, MESSAGE_MAX+PSEUDO_MAX, 0)) == -1) {
perror("Client: recv");
return EXIT_FAILURE;
}
// ...
char* message;
message = malloc (sizeof(char) * MESSAGE_MAX);
// Here I launch the thread to write a message
pthread_t thread;
if (pthread_create(&thread, NULL, thread_message, &sockfd)) {
perror("pthread_create");
return EXIT_FAILURE;
}
}
// Here I print the messages I receive
else
{
buf[numbytes] = '\0';
printf("%s",buf);
}
}
close(sockfd);
return EXIT_SUCCESS;
}
感谢您的帮助! :)
答案 0 :(得分:1)
解决问题的一种方法:可能使用ncurses
中的getch
。将已输入的内容保存到缓冲区中。并在终端的不同行显示来自其他客户端的消息和您的输入。
注意:我之前从未使用过libncurses,但是当我看到ncurses
的{{3}}时,我知道它可以满足聊天程序的需要。希望有所帮助。
答案 1 :(得分:0)
首先,我相信你的头衔与你的问题不符。你想知道用线程打印,对吗?其次,尝试更详细地解释每条消息的来源以及您感到困惑的地方。
说,我相信你的问题是线程同步。
:)