采用的系统调用函数是epoll_wait()。
while(1){
// 得到最近且未删除时间和当前时间差值(等待时间)
int time = tk_find_timer();
// 调用epoll_wait函数,返回接收到事件的数量
int events_num = tk_epoll_wait(epoll_fd, events, MAXEVENTS, -1);
// 处理(删除/标记)已经超时的请求,懒惰删除
tk_handle_expire_timers();
// 遍历events数组,根据监听种类及描述符类型分发操作
tk_handle_events(epoll_fd, listen_fd, events, events_num, conf.root, tp);
}
// 返回活跃事件数
//此处代码有问题,如果事件超过最大值,应该对events进行扩容
int tk_epoll_wait(int epoll_fd, struct epoll_event* events, int max_events, int timeout){
int ret_count = epoll_wait(epoll_fd, events, max_events, timeout);//等待事件的产生,并返回待处理事件数目
return ret_count;
}
-
#include <sys/epoll.h> int epoll_wait(int epfd,struct event* events,int maxevents,int timeout); //该函数成功时返回就绪文件描述符个数,失败时返回-1,并设置errno //maxevents指定最多监听多少个事件 //epoll_wait如果检测到就绪事件,就将所有就绪事件从内核事件表复制到events指向的数组里, // 前面说过events里event_data_t联合结构体有一个void型指针变量 //它与select/poll不同之处在于,select/poll需要传入用户注册事件,输出内核检测到的事件
在这个代码里event里的指针指向了request结构体,所以事件会存储到request中