socket多个客户端连接服务器【上】:select服务器&epoll客户端

本文介绍了如何使用select实现服务器端的多客户端连接处理,以及客户端如何利用epoll进行高效通信。在服务器端,通过select监控客户端连接和读取信息,当有新的连接请求时,accept并保存文件描述符。客户端则使用epoll创建句柄,注册文件描述符事件,通过epoll_wait等待事件发生,进行读写操作。总结指出,epoll在处理高并发时效率优于select。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、select服务器

#include <stdio.h>
#include <netinet/in.h>   
#include <sys/socket.h>
#include <errno.h>
#include <stdlib.h>
#include <arpa/inet.h>
#include <sys/time.h>
#include <unistd.h>
#include <sys/select.h>
#include <string.h>

网络socket通信必要的头文件

#define BUFF_SIZE 1024
#define backlog 7
#define ser_port 3344
#define CLI_NUM 3

定义一些宏,其中backlog为listen允许监听个数,ser_port为端口号,CLI_NUM为客户端最大连接数

//两个有用的宏定义:检查和赋值并且检测
#define CHK(eval) if(eval < 0){perror("eval"); exit(-1);}
#define CHK2(res, eval) if((res = eval) < 0){perror("eval"); exit(-1);}

用于返回值检查的宏

int client_fds[CLI_NUM];

用于保存客户端连接,文件描述符的数组

int main(int agrc,char **argv) {
	int ser_sock_fd;
	int i;
	char input_message[BUFF_SIZE];
	char resv_message[BUFF_SIZE];
	
	memset(client_fds,0,CLI_NUM);

	struct sockaddr_in ser_addr;
	ser_addr.sin_family= AF_INET;    //IPV4
	ser_addr.sin_port = htons(ser_port);
	ser_addr.sin_addr.s_addr =htonl(INADDR_ANY);  //指定的是所有地址

	//creat socket
	CHK2(ser_sock_fd,socket(AF_INET,SOCK_STREAM,0));

	//bind socket
	CHK(bind(ser_sock_fd, (const struct sockaddr *)&ser_addr,sizeof(ser_addr)) < 0);

	//listen
	CHK(listen(ser_sock_fd, backlog) < 0);

一般的服务器socket创建过程,创建、绑定、监听

	//fd_set
	fd_set ser_fdset;
	int max_fd=1;
	struct timeval mytime;
	printf("wait for client connnect!\n");

定义select将要操作的集合ser_fdset,初始化最大文件描述符max_fd为1,定义超时时间mytime</

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值