在Linux中,套接字(socket)本身并不直接支持多线程
以下是一个简单的示例,展示了如何在C语言中使用多线程处理TCP连接:
#include <arpa/inet.h>
#include <netinet/in.h>
#include <pthread.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <unistd.h>
#define PORT 8080
#define BUFFER_SIZE 1024
void *handle_client(void *arg);
int main() {
int server_fd, client_fd;
struct sockaddr_in server_addr, client_addr;
socklen_t addr_len = sizeof(client_addr);
pthread_t thread_id;
// 创建套接字
if ((server_fd = socket(AF_INET, SOCK_STREAM, 0)) == 0) {
perror("socket failed");
exit(EXIT_FAILURE);
}
// 配置服务器地址
server_addr.sin_family = AF_INET;
server_addr.sin_addr.s_addr = INADDR_ANY;
server_addr.sin_port = htons(PORT);
// 绑定套接字
if (bind(server_fd, (struct sockaddr *)&server_addr, sizeof(server_addr)) < 0) {
perror("bind failed");
exit(EXIT_FAILURE);
}
// 监听连接
if (listen(server_fd, 3) < 0) {
perror("listen");
exit(EXIT_FAILURE);
}
printf("Server is listening on port %d\n", PORT);
while (1) {
// 接受客户端连接
if ((client_fd = accept(server_fd, (struct sockaddr *)&client_addr, (socklen_t *)&addr_len)) < 0) {
perror("accept");
exit(EXIT_FAILURE);
}
// 为每个客户端连接创建一个新线程
if (pthread_create(&thread_id, NULL, handle_client, (void *)&client_fd) != 0) {
perror("pthread_create");
exit(EXIT_FAILURE);
}
// 等待线程结束
pthread_join(thread_id, NULL);
}
close(server_fd);
return 0;
}
void *handle_client(void *arg) {
int client_fd = *((int *)arg);
char buffer[BUFFER_SIZE] = {0};
// 读取客户端发送的数据
read(client_fd, buffer, BUFFER_SIZE);
printf("Received from client: %s\n", buffer);
// 向客户端发送数据
send(client_fd, "Hello from server!", strlen("Hello from server!"), 0);
printf("Sent to client: Hello from server!\n");
// 关闭套接字
close(client_fd);
return NULL;
}
在这个示例中,我们创建了一个TCP服务器,监听8080端口。当客户端连接时,服务器会为每个客户端创建一个新线程来处理连接。这样,多个客户端可以同时与服务器通信,实现了多线程处理。