多路复用器java代码 多路复用器java代码怎么写( 四 )


fds还是关注的描述符列表 。poll将events和reevents分开了,所以如果关注的events没有发生变化就可以重用fds,poll只修改rents不会动events 。fds是个数组,不是fds_set,没有了上限 。
相对于select,poll解决了fds长度上限问题,解决了监听描述符无法复用问题,但仍需在poll返回后遍历fds去找ready的描述符,也要清理ready描述符对应的revents,Kernel也同样是每次poll调用需要去遍历fds注册监听,poll返回时拆除监听 , 也仍有惊群问题 , 无法动态修改描述符的问题 。
使用步骤:
优点 :
缺点 :
changelist用于传递关心的event
nchanges用于传递changelist的大小
eventlist用于当有事件产生后,将产生的事件放在这里
nevents用于传递eventlist大小
timeout 超时时间
kqueue高级的地方在于,它监听的不一定非要是Socket,不一定非要是文件 , 可以是一系列事件,所以struct kevent内参数叫filter,用于过滤出关心的事件 。
kqueue有epoll所有优点,还能通过changelist一次注册多个关心的event,不需要像epoll那样每次调用epoll_ctl去配置
当我们执行epoll_ctl时,除了把socket放到epoll文件系统里file对象对应的红黑树上之外,还会给内核中断处理程序注册一个回调函数,告诉内核,如果这个句柄的中断到了,就把它放到准备就绪list链表里 。所以,当一个socket上有数据到了,内核在把网卡上的数据copy到内核中后就来把socket插入到准备就绪链表里 。
如此 , 一棵红黑树,一张准备就绪句柄链表 , 少量的内核cache,就帮我们解决了大并发下的socket处理问题 。执行epoll_create时,创建了红黑树和就绪链表,执行epoll_ctl时 , 如果增加socket句柄 , 则检查在红黑树中是否存在,存在立即返回,不存在则添加到树干上,然后向内核注册回调函数,用于当中断事件来临时向准备就绪链表中插入数据 。执行epoll_wait时立刻返回准备就绪链表里的数据即可 。
Epoll有两种触发模式,一种Edge Trigger简称ET,一种Level Trigger简称LT 。每个使用epoll_ctl注册在epoll描述符上的被监听的描述符都能单独配置自己的触发模式 。
从使用角度的区别:ET模式下当一个文件描述符Ready后,需要以Non-Blocking方式一直操作这个FD直到操作返回EAGAIN错误位置,期间Ready这个事件只会触发epoll_wait一次返回 。LT模式,如果FD上的事件一直处在Ready状态没处理完,则每次调用epoll_wait都会立即返回
场景:
Java的NIO提供了Selector类,用于跨平台的实现Socket Polling , 即IO多路复用 。BSD系统上对应的是Kqueue,Window上对应的是Select , Linux上对应的是LT的Epoll(为了跨平台统一,Windows上背后是Select,是LT的)
Selector的使用:
多路复用器java代码的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于多路复用器java代码怎么写、多路复用器java代码的信息别忘了在本站进行查找喔 。