【Java面试】什么是IO的多路复用机制?
“什么是IO的多路复用机制?”
这是一道年薪50W的面试题,很遗憾,99%的人都回答不出来。
大家好,我是Mic,一个工作了14年的Java程序员。
今天,给大家分享一道网络IO的面试题。
这道题目的文字回答已经整理到了15W字的面试文档里面,大家可以S我领取。
下面看看高手的回答。
高手:
IO多路复用机制,核心思想是让单个线程去监视多个连接,一旦某个连接就绪,也就是触发了读/写事件。
就通知应用程序,去获取这个就绪的连接进行读写操作。
也就是在应用程序里面可以使用单个线程同时处理多个客户端连接,在对系统资源消耗较少的情况下提升服务端的链接处理数量。
在IO多路复用机制的实现原理中,客户端请求到服务端后,此时客户端在传输数据过程中,为了避免Server端在read客户端数据过程中阻塞,服务端会把该请求注册到Selector复路器上,服务端此时不需要等待,只需要启动一个线程,通过selector.select()阻塞轮询复路器上就绪的channel即可,也就是说,如果某个客户端连接数据传输完成,那么select()方法会返回就绪的channel,然后执行相关的处理就可以了。
常见的IO多路复用机制的实现方式有: select 、poll、epoll。
这些都是Linux系统提供的IO复用机制的实现,其中select和poll是基于轮询的方式去获取就绪连接。
而epoll是基于事件驱动的方式获取就绪连接。从性能的角度来看,基于事件驱动的方式要优于轮询的方式。
总结
IO多路复用机制,是非常重要的网络通信基础。
在平时的业务开发中,使用比较少,但是在中间件里面作为基础通信模型,是每个高级工程师必须要掌握的内容。
大家记得点赞、收藏加关注。
版权声明:本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自
Mic带你学架构
!
如果本篇文章对您有帮助,还请帮忙点个关注和赞,您的坚持是我不断创作的动力。欢迎关注「跟着Mic学架构」公众号公众号获取更多技术干货!
相关文章
- 冷饭新炒:理解JDK中UUID的底层实现
- 玩转IDEA项目结构Project Structure,打Jar包、模块/依赖管理全搞定
- 求职中最吃香的编程语言:JavaScript、Java 和 Python
- Gitee发布2020开源年报:Java稳居语言占比第一 PHP排名第三
- 实战派 | Java项目中玩转Redis6.0客户端缓存!
- 如何为Jenkins设置自定义UI主题
- 记一次线上Java程序故障惊心动魄两小时
- JVM性能调优实战:让你的IntelliJ Idea纵享丝滑
- 利用Jenkins与Nginx实现前端项目自动构建与持续集成
- Java开发人员需要了解的地域分布数据库
- Java微服务 vs Go微服务,究竟谁更强?
- Github接近10w点赞!Java面试必备开源指南
- 五分钟快速掌握Maven的核心概念
- 1.1w字,10图彻底掌握阻塞队列(并发必备)
- 10分钟搞定让你困惑的 Jenkins 环境变量
- Java程序员发展前景怎么样?大不大?
- 12月份GitHub上热门的Java开源项目
- 6个技巧轻松掌握JVM内存调优
- 面向初学者的Jenkins多分支管道教程
- 跳表(SkipList)设计与实现(Java)