【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学架构」公众号公众号获取更多技术干货!
最新文章
- Git 源代码管理工具
- 通过泛型数据,操作SQL数据库
- centos: vmware 安装centos 7连不上网
- 设置eclipse补全方法
- VC2010 _com_error 返回的错误信息
- 在Abp框架中使用Mysql数据库的方法以及相关问题小记
- 【宽搜】Vijos P1206 CoVH之再破难关
- javascript第十四课,方法的扩展prototype
- [UWP小白日记-6]页面跳转过度动画
- 制作一个功能丰富的Android天气App
- 重启osd服务失败:Start request repeated too quickly
- [翻译] 编写高性能 .NET 代码--第二章 GC -- 减少大对象堆的碎片,在某些情况下强制执行完整GC,按需压缩大对象堆,在GC前收到消息通知,使用弱引用缓存对象
- centos7 支持中文显示
- Java(16)接口
- 2019浙大校赛--J--Extended Twin Composite Number(毒瘤水题)
- SDE表空间不足解决办法(ORA-01653)
- Python sqlalchemy orm 多外键关联
- Linux下HBase和Maven的环境搭建
- JS计算滚动条的宽度
- bzoj1609 / P2896 [USACO08FEB]一起吃饭Eating Together(最长不降子序列)
热门文章
- 关于我学git这档子事
- .Net分表分库动态化处理
- 【JNPF修改通告】fastjson≤1.2.80反序列化漏洞
- UNION 与 UNION ALL 的区别
- 中国程序员容易发错音的单词「GitHub 热点速览 v.22.23」
- csv.reader(f)和f.readlines()、追加数据
- 部署ASP.NET Core最简单的办法,使用IIS部署ASP.NET Core应用
- Django——表单
- SpringBoot整合SpringSecurityOauth2实现鉴权-动态权限
- React中setState方法说明