我正在写一个简单的http服务器,首先我们看一下这部分代码:
static void *connection_handler(void *connection) {
/* cast the connection */
Connection *c = (Connection*)connection;
HttpRequest req;
char buffer[1024];
size_t bytes_recv = recv(c->s, buffer, 1024, 0);
parse_http_request(&req, buffer, bytes_recv);
printf("Received connection!");
//printf("%s", buffer);
/* cleanup */
krystal_close_socket(c->s);
free(connection);
return NULL;
}
这是我的连接处理程序,每个连接我都会将其推送到线程 vector ,然后我遇到了奇怪的错误。当带有接收到的数据的 printf 被注释时,所有“已接收连接”消息在服务器循环停止后都会显示(我已设置为在 5 个连接后停止服务器)但是..当我在每个连接工作时打印接收到的数据时,缓冲区是打印在每个连接上。 WTF?!
最佳答案
好吧,当我添加“\n”和打印消息时,它开始工作,接下来我尝试 fflush(stdout) 并且仍然工作。所以我现在的问题是,打印 '\n\字符与 fflush(stdout) 做同样的事情吗?
关于c - 多线程处理http请求时会发生奇怪的事情,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48255689/