Linux 下的IO多路复用技术的小总结(select、poll、epoll直接的区别总结)
1、IO多路复用基本概念
IO多路复用是指内核一旦发现进程指定的一个或者多个IO条件准备读取,它就通知该进程。IO多路复用适用如下场合:
(1)当客户处理多个描述字时(一般是交互式输入和网络套接口),必须使用I/O复用。
(2)当一个客户同时处理多个套接口时,而这种情况是可能的,但很少出现。
(3)如果一个TCP服务器既要处理监听套接口,又要处理已连接套接口,一般也要用到I/O复用。
(4)如果一个服务器即要处理TCP,又要处理UDP,一般要使用I/O复用。
(5)如果一个服务器要处理多个服务或多个协议,一般要使用I/O复用。
与多进程和多线程技术相比,I/O多路复用技术的最大优势是系统开销小,系统不必创建进程/线程,也不必维护这些进程/线程,从而大大减小了系统的开销。
2、select介绍
#include <sys/select.h>
#include <sys/time.h>
int select(int maxfdp, fd_set *readset, fd_set *writeset, fd_set *exceptset, const struct timeval *timeout)
返回值:就绪描述符的数目,超时返回0,出错返回-1
函数参数介绍:
(1)maxfdp: 这个参数表示待测的描述符个数,其值是待测的最大描述符加1,文件描述符是从0开始的。
(2)中间的三个参数都是fd_set类型的,分别表示的是让内核测试读、写和异常条件的描述符集合,可以根据自己的使用条件来设置,不设置可设为NULL,struct fd_set可以理解成一个集合,该集合是用来存放文件描述符。
....未完...待续...