“什么是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学架构」公众号公众号获取更多技术干货!

最新文章

  1. Git 源代码管理工具
  2. 通过泛型数据,操作SQL数据库
  3. centos: vmware 安装centos 7连不上网
  4. 设置eclipse补全方法
  5. VC2010 _com_error 返回的错误信息
  6. 在Abp框架中使用Mysql数据库的方法以及相关问题小记
  7. 【宽搜】Vijos P1206 CoVH之再破难关
  8. javascript第十四课,方法的扩展prototype
  9. [UWP小白日记-6]页面跳转过度动画
  10. 制作一个功能丰富的Android天气App
  11. 重启osd服务失败:Start request repeated too quickly
  12. [翻译] 编写高性能 .NET 代码--第二章 GC -- 减少大对象堆的碎片,在某些情况下强制执行完整GC,按需压缩大对象堆,在GC前收到消息通知,使用弱引用缓存对象
  13. centos7 支持中文显示
  14. Java(16)接口
  15. 2019浙大校赛--J--Extended Twin Composite Number(毒瘤水题)
  16. SDE表空间不足解决办法(ORA-01653)
  17. Python sqlalchemy orm 多外键关联
  18. Linux下HBase和Maven的环境搭建
  19. JS计算滚动条的宽度
  20. bzoj1609 / P2896 [USACO08FEB]一起吃饭Eating Together(最长不降子序列)

热门文章

  1. 关于我学git这档子事
  2. .Net分表分库动态化处理
  3. 【JNPF修改通告】fastjson≤1.2.80反序列化漏洞
  4. UNION 与 UNION ALL 的区别
  5. 中国程序员容易发错音的单词「GitHub 热点速览 v.22.23」
  6. csv.reader(f)和f.readlines()、追加数据
  7. 部署ASP.NET Core最简单的办法,使用IIS部署ASP.NET Core应用
  8. Django——表单
  9. SpringBoot整合SpringSecurityOauth2实现鉴权-动态权限
  10. React中setState方法说明