Bootstrap

select,poll和epoll有什么区别

他们是NIO中实现多路复用的三种实现机制,是由Linux操作系统提供的。
用户空间和内核空间:操作系统为了保护系统安全,将内核划分为两个部分,一个是用户空间,一个是内核空间。用户空间不能直接访问底层的硬件设备,必须通过内核空间。
文件描述符 File Descriptor(FD) : 是一个抽象的概念,形式上是一个整数。实际上是一个索引值。指向内核中为每一个进程维护进程所打开的文件的记录表。当程序打开一个文件或者创建一个文件时,内核就会返回一个FD。Unix,Linux

sekect 机制:会维护一个FD的结合fd_set。将fd_set从用户空间复制到内核空间,激活socket。 x64 2048 fd_set是一个数组结构
poll 机制:和select机制是差不多的,把fd_set结构进行了优化,FD集合的大小就突破了操作系统的限制。pollfd结构来代替fd_set,通过链表实现。
EPoll:Event Poll.Epoll不在扫描所有的FD,只将用户关心的FD的事件存放到内核的事件表当中。这样,可以减少用户空间与内核空间之前需要拷贝的数据。

总结:操作方式底层实现最大连接数io效率发布年
select遍历数组受限于内核一般1984
pol遍历链表无上限一般高1997
epoll事件回调红黑树无上限2022

java的NIO 在windows下 WindowsSelectorProvider,Linux下,根据linux的内核版本,2.6版本以上,就是EPollSelectProvider,否则就是默认的PollSelectProvider,

;