linux网络编程多线程收发
时间: 2023-10-06 15:08:54 浏览: 98
在Linux网络编程中,使用多线程进行收发操作可以提高网络应用程序的并发性能。下面是一个简单的示例代码,说明如何使用多线程进行收发操作。
```c
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <pthread.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#define MAX_CLIENTS 10
void *handle_client(void *arg) {
int client_fd = *(int *)arg;
char buffer[1024];
memset(buffer, 0, sizeof(buffer));
// 接收客户端数据
ssize_t recv_len = recv(client_fd, buffer, sizeof(buffer), 0);
if (recv_len > 0) {
printf("Received message from client: %s\n", buffer);
}
// 发送响应给客户端
char response[] = "Hello from server!";
ssize_t send_len = send(client_fd, response, sizeof(response), 0);
if (send_len == -1) {
perror("send");
}
close(client_fd);
pthread_exit(NULL);
}
int main() {
int server_fd;
struct sockaddr_in server_addr;
struct sockaddr_in client_addr;
socklen_t client_addr_len = sizeof(client_addr);
pthread_t threads[MAX_CLIENTS];
// 创建套接字
server_fd = socket(AF_INET, SOCK_STREAM, 0);
if (server_fd == -1) {
perror("socket");
exit(1);
}
// 设置服务器地址
server_addr.sin_family = AF_INET;
server_addr.sin_addr.s_addr = INADDR_ANY;
server_addr.sin_port = htons(8080);
// 绑定套接字到服务器地址
if (bind(server_fd, (struct sockaddr *)&server_addr, sizeof(server_addr)) == -1) {
perror("bind");
exit(1);
}
// 监听连接
if (listen(server_fd, MAX_CLIENTS) == -1) {
perror("listen");
exit(1);
}
printf("Server started. Listening on port 8080...\n");
// 接受并处理客户端请求
int i = 0;
while (1) {
int client_fd = accept(server_fd, (struct sockaddr *)&client_addr, &client_addr_len);
if (client_fd == -1) {
perror("accept");
continue;
}
// 创建线程处理客户端请求
if (pthread_create(&threads[i], NULL, handle_client, &client_fd) != 0) {
perror("pthread_create");
continue;
}
// 分离线程
pthread_detach(threads[i]);
i++;
if (i >= MAX_CLIENTS) {
break;
}
}
close(server_fd);
return 0;
}
```
在上面的示例代码中,首先创建了一个服务器套接字,然后绑定到指定的IP地址和端口号。接着,使用`listen`函数监听来自客户端的连接请求。
在主循环中,通过调用`accept`函数接受客户端连接,并且为每个客户端连接创建一个新的线程来处理收发操作。`handle_client`函数是在线程中执行的任务,负责接收客户端数据并发送响应给客户端。
需要注意的是,在多线程编程中,要确保网络资源的正确管理和共享,避免竞争条件和死锁等问题的出现。