“什么是IO的多路复用机制?”高手: IO多路复用机制,核心思想是让单个线程去监视多个连接,一旦某个连接就绪,也就是触发了读/写事件。
这是一道年薪50W的面试题,很遗憾,99%的人都回答不出来。
大家好,我是Mic,一个工作了14年的Java程序员。
今天,给大家分享一道网络IO的面试题。
这道题目的文字回答已经整理到了15W字的面试文档里面,大家可以S我领取。
下面看看高手的回答。
就通知应用程序,去获取这个就绪的连接进行读写操作。
也就是在应用程序里面可以使用单个线程同时处理多个客户端连接,在对系统资源消耗较少的情况下提升服务端的链接处理数量。
在IO多路复用机制的实现原理中,客户端请求到服务端后,此时客户端在传输数据过程中,为了避免Server端在read客户端数据过程中阻塞,服务端会把该请求注册到Selector复路器上,服务端此时不需要等待,只需要启动一个线程,通过selector.select()阻塞轮询复路器上就绪的channel即可,也就是说,如果某个客户端连接数据传输完成,那么select()方法会返回就绪的channel,然后执行相关的处理就可以了。
文章图片
常见的IO多路复用机制的实现方式有: select 、poll、epoll。
这些都是Linux系统提供的IO复用机制的实现,其中select和poll是基于轮询的方式去获取就绪连接。
【【Java面试】什么是IO的多路复用机制()】而epoll是基于事件驱动的方式获取就绪连接。从性能的角度来看,基于事件驱动的方式要优于轮询的方式。
总结 IO多路复用机制,是非常重要的网络通信基础。
在平时的业务开发中,使用比较少,但是在中间件里面作为基础通信模型,是每个高级工程师必须要掌握的内容。
大家记得点赞、收藏加关注。
文章图片
版权声明:本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自Mic带你学架构
!
如果本篇文章对您有帮助,还请帮忙点个关注和赞,您的坚持是我不断创作的动力。欢迎关注同名微信公众号获取更多技术干货!
推荐阅读
- 经验分享|拥抱新技术(你需要考虑的方面)
- 算法|基于MATLAB的图像去噪与边缘检测技术
- java|抖音API接口(item_search-根据关键词取商品列表)
- java|抖音API接口(item_get-获得抖音商品详情)
- Java|Inno Setup使用教程 - 打包SpringBoot+Vue前后端分离项目
- redis|Redis的使用--Java连接redis、springboot整合redis、缓存 分布锁 、redssion解决分布锁的bug(超时问题) 以及redis常见面试题
- VUE.JS|Vue+Springboot前后端分离(入门级)
- ssm整合|SSM整合shiro安全框架
- java|蚂蚁金服5面,总结了49个面试题,遇到的面试官都是P7级别以上