• 【Java面试】什么!年薪50W就问这?我照着高手回答直接背能拿吗?请查收


    “什么是IO的多路复用机制?”

    这是一道年薪50W的面试题,很遗憾,99%的人都回答不出来。

    今天,给大家分享一道网络IO的面试题。

    这道题目的文字回答已经整理到了15W字的面试文档里面,

    下面看看高手的回答。

    就通知应用程序,去获取这个就绪的连接进行读写操作。

    也就是在应用程序里面可以使用单个线程同时处理多个客户端连接,在对系统资源消耗较少的情况下提升服务端的链接处理数量。

    在IO多路复用机制的实现原理中,客户端请求到服务端后,此时客户端在传输数据过程中,为了避免Server端在read客户端数据过程中阻塞,服务端会把该请求注册到Selector复路器上,服务端此时不需要等待,只需要启动一个线程,通过selector.select阻塞轮询复路器上就绪的channel即可,也就是说,如果某个客户端连接数据传输完成,那么select方法会返回就绪的channel,然后执行相关的处理就可以了。

    image.png

    常见的IO多路复用机制的实现方式有: select 、poll、epoll。

    这些都是Linux系统提供的IO复用机制的实现,其中select和poll是基于轮询的方式去获取就绪连接。

    而epoll是基于事件驱动的方式获取就绪连接。从性能的角度来看,基于事件驱动的方式要优于轮询的方式。

    IO多路复用机制,是非常重要的网络通信基础。

    在平时的业务开发中,使用比较少,但是在中间件里面作为基础通信模型,是每个高级工程师必须要掌握的内容。

    需要高手面试文档(附赠大厂内部十万字面试文档)或者有不懂的技术面试题想咨询的小伙伴可以后台【Mic】或者评论区留言。

  • 相关阅读:
    go: no such tool “compile“(一次糟糕体验)
    Oracle-Rman duplicate文件坏块问题处理ORA-19849 19612
    生信步骤|转录组mRNA数据的有参组装
    【C++】AVL树的简单实现
    ShuffleNetV1:极致轻量化卷积神经网络(分组卷积+通道重排)
    汇编-间接寻址(处理数组)
    自主SSL品牌—JoySSL
    [Docker] Docker常用命令
    pytorch学习第三篇:梯度
    DBSync数据库同步工具
  • 原文地址:https://blog.csdn.net/m0_60721514/article/details/126199769