客户端如何使用套接字同时发送和接收消息?

时间:2014-12-16 12:28:28

标签: c multithreading sockets chat

我创建了一个包含客户端和服务器的聊天室,一切正常。但我有打印问题。问题是客户端可以编写他的消息并同时从其他客户端读取消息。所以我用一个线程同时做两个。它可以工作,但看一下示例问题是什么:

  

在这里,我开始写我的第一个混乱,这是收到的消息,打断了我的写作,在这里我继续写作

我不知道它是否清楚:我开始写一条消息,但我还没有发送消息,因为它没有结束但是同时收到一条消息所以它会在我写作信息开始之后和我可以继续写作之后打印出来。

您是否知道如何解决问题?

以下是客户端代码:

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;
} 

感谢您的帮助! :)

2 个答案:

答案 0 :(得分:1)

解决问题的一种方法:可能使用ncurses中的getch。将已输入的内容保存到缓冲区中。并在终端的不同行显示来自其他客户端的消息和您的输入。

注意:我之前从未使用过libncurses,但是当我看到ncurses的{​​{3}}时,我知道它可以满足聊天程序的需要。希望有所帮助。

答案 1 :(得分:0)

首先,我相信你的头衔与你的问题不符。你想知道用线程打印,对吗?其次,尝试更详细地解释每条消息的来源以及您感到困惑的地方。

说,我相信你的问题是线程同步

  • 线程如何运作?以一种非常简单的方式,每个线程都会 有一个时间片来执行,然后,它将为其他人提供空间 程序中的线程要执行。这就是你必须使用互斥的原因 访问共享变量,因此线程不使用旧值或 覆盖数据。
  • 如何一致打印?好吧,你可以使用信号量。检查此其他stackoverflow question。在谷歌上查看C中的示例,但是这篇文章为您提供了解决这一问题的基本知识。

:)