NIO底层:IO多路复用与Select/Poll/Epoll

本文深入探讨了Java NIO中的IO多路复用技术,重点分析了select、poll和epoll的工作步骤及优缺点。epoll作为Linux2.6内核提出的改进方案,通过事件就绪通知和回调机制,解决了select和poll在大规模文件描述符处理时的性能问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

IO多路复用

相信各位小伙伴在学习JavaIO知识时会看到其底层实现是使用了操作系统中的IO多路复用
那么IO多路复用到底是什么呢?
面试题中出现的select/poll/epoll,poll和epoll的区别又指的是什么呢?
今天我就带大家来看下:

I/O多路复用(multiplexing)的本质是通过一种机制(系统内核缓冲I/O数据),让单个进程可以监视多个文件描述符,一旦某个描述符就绪(一般是读就绪或写就绪),能够通知程序进行相应的读写操作

在这里插入图片描述

Select:
工作步骤:
  • 将fd_set(文件描述符集合)从用户空间拷贝至内核空间
  • 遍历所有的fd_set判断是否有就绪的fd
    • 有:将其从内核空间拷贝到用户空间进行操作
    • 无:进入睡眠,等待设备驱动可读写后被唤醒
缺点:
  1. 每次调用select,都需要把fd_set集合从用户态拷贝到内核态,如果fd_set集合很大时,那这个开销也很大。
  2. 同时每次调用select都需要在内核遍历传递进来的所有fd_set,如果fd_set集合很大时,那这个开销也很大。
  3. 为了减少数据拷贝带来的性能损坏,内核对被监控的fd_set集合大小做了限制,并且这个是通过宏控制的,大小不可改变(限制为1024)。
<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值