1.select跨平台最好,连windows都支持,
但有下面缺点:
1)windows下FD_SIZE默认64,也就是默认最大支持监视socket数,但在包含winsock,h之前可以修改源码,就行。
linux内核也限制了是1024,但也可以修改内核源码,编译,不过这个好麻烦。。。
2)每次socket状态发生变化,就要遍历整个数组检测是否当前socket有事件发生,这样是O(n)
3)select会引发内核态和用户态的切换,有内存拷贝开销,不过这个我不怎么理解。(内核把FD消息通知给用户空间)
2、poll没有select最大FD的限制,其他缺点还在;
3、epoll
优点:
1)当然没有FDmax限制,当然跟能打开的maxFile也有关了,不过65536以内应该木有问题;
2)基于事件的通知方式,select是app自己要遍历检测,而epoll是实现注册进去,如果有时间发生内核会激活这个FD,epoll_wait就会得到通知,传回事件数组,然后根据事件类型app去执行可读可写就行了
3)没有内存拷贝的开销。用了内存映射。
之前没接触过内存映射:
内存映射,简而言之就是将用户空间的一段内存区域映射到内核空间,映射成功后,用户对这段内存区域的修改可以直接反映到内核空间,相反,内核空间对这段区域的修改也直接反映用户空间。那么对于内核空间<---->用户空间两者之间需要大量数据传输等操作的话效率是非常高的。
好吧,暂时总结到这里。