poll也是一种linux中的多路转接方案(poll也是只负责IO过程中的"等")
解决:1.select的fd有上限的问题;2.每次调用都要重新设置关心的fd
一、poll的使用
int poll(struct pollfd *fds, nfds_t nfds, int timeout);
① struct pollfd *fds:动态数组(struct pollfd类型的数组)
② nfds_t nfds:数组元素个数
③ int timeout:>0 在timeout以内阻塞,否则非阻塞返回一次;=0 非阻塞等待;<0 阻塞等待
④ 返回值:同select(ret>0:返回有几个fd就绪了;ret==0:超时返回了;ret<0:调用失败)
struct pollfd结构体
struct pollfd { int fd; short events; short revents; };
events 用户告诉内核(输入型):要帮我关心fd的event事件 -> 输入看fd+events
revents 内核告诉用户(输出型):你关心的fd有哪些事已经就绪了 -> 输出看fd+revents
events和revents的取值
二、poll的特点
1.输入输出分离:poll不需要对参数进行重新设定
2.自定义数组个数:解决select等待fd有上限的问题
3.poll需要遍历整个struct pollfd *fds数组 -> 为了解决这种问题 -> epoll