- select每次调用
select()
时都要传入fds数组,而epoll在内核维护了一个等待队列,每次调用epoll_wait()
时不需要传入等待队列进去,只在执行epoll_ctl()
时才更新等待队列。降低了内核与用户层的数据迁移; select()
返回后每次都要遍历所有被监视的文件描述符,而epoll_wait()
返回时已经将有事件发生的文件描述符放到了一个数组中,所以用户层只需要遍历有事件发生的文件描述符即可,大大降低了遍历范围;- select是将当前进程添加到每个被监视的socket的等待队列里面,等事件发生时,就会从所有socket的等待队列里面移除当前进程,并将当前进程放到工作队列里面,从而唤醒当前进程来处理。epoll并不直接处理进程,epoll通过
epoll_create()
创建的epoll例程中会有一个就绪列表,当某个socket有事件发生时,内核会将此socket的引用存入到就绪列表里面。而epoll_wait()
查看就绪列表是否为空,如果为空,就阻塞进程,如果不为空,就唤醒进程。
epoll比select高效的原因
最新推荐文章于 2022-12-17 11:23:36 发布