它们都是NIO中多路复用的三种实现机制,是由linux操作系统提供的。
用户空间和内核空间:操作系统为了保证系统安全,将内核分为两个部分,一个是用户空间,一个是内核空间。用户空间不能直接访问底层的硬件设备,必须通过内核空间。
文件描述符(File Description FD):是一个抽象的概念,形式上是一个整数,实际是一个索引值,指向内核中每个进程维护进程所打开文件的记录表。当程序打开一个文件或者创建一个文件时,内核会向进程返回一个FD,主要在unix和linux系统中。
select机制
会维护一个FD的集合fd_set。将fd_set从用户空间复制到内核空间。激活socket。fd_set是一个数组,并且受到操作系统的限制。
poll机制
将fd_set结构进行了优化。FD集合的大小就突破了操作系统的限制。使用poll_fd结构来代替fd_set。通过链表实现。
EPoll
Event Poll不再扫描所有的fd,只将用户关心的FD事件放到内核的事件表当中。这样,可以减少用户空间和内核空间之间需要拷贝的数据。
java中的NIO用的是哪种机制
可以查看DefaultSelectProvider源码。在windows下,使用的是WindowsSelectorProvider。而在linux下,会根据Linux的内核版本控制,2.6版本以上使用的是EpollSelectProvider,否则就是默认的PollSelectorProvider。