I/O复用:一个进程或者一个线程能够同时对多个文件描述符(socket)
epoll
epoll:Linux独有(效率比其他两种I/O复用高)——>将用户关注的文件描述符上的事件直接由内核记录
首先我们需要了解epoll的函数原型:
epoll需要的函数原型:
int epoll_creat(int size); //创建一个内核事件表,返回事件表的标记,文件描述符。———>底层用红黑树建成
int epoll_ctl(int epfd,int op,int fd, struct epoll_event * event); ———>设置(添加、修改、删除)内核事件表中的文件描述符上的事件
int epollfd:创建内核事件表的标记
int op:命令
命令有:
EPOLL_CTL_ADD//添加
EPOLL_CTL_MOD//修改
EPOLL_CTL_DEL//删除
int fd:操作哪一个文件描述符
struct epoll_event *event:
int epoll_wait(int epollfd, struct epoll_event * revents,int length, int timeout);——>内核去监听
epoll_wait:返回就绪文件描述符的个数 revents:只返回就绪的文件描述符
int epollfd:内核事件表的id
struct epoll_event *revents:
该数组中_uint32_t events;为用户关注的事件
epoll_data_t data为:
int length:数组大小
int timeout:超时时间
epoll与select,poll简单对比:
I/O复用使用epoll下TCP服务器的实现(客户端与TCP的相同):
一个客户端与服务器连接如图(连接成功):
多个客户端与服务器连接如图(连接成功):