当前位置: 首页 > news >正文

NIO三大组件

文章目录

  • 概述
  • Channel & Buffer
  • Selector
    • 服务器设计历史演化
      • 多线程版设计
      • 线程池版设计
      • selector 版设计

概述

NIO的意思是 non-blocking io 非阻塞 IO 。NIO中存在3大组件:Channel 、 Buffer 、Selector

Channel & Buffer

channel (中文 管道的意思)有一点类似于 stream,它就是读写数据的双向通道,可以从 channel 将数据读入 buffer(中文 缓冲区的意思),也可以将 buffer 的数据写入 channel,而之前的 stream 要么是输入,要么是输出,channel 比 stream 更为底层。Channel和Buffer是多对多的关系,它们相互协作共同完成数据的传输和处理任务

在这里插入图片描述

常见的 Channel 有

  • FileChannel (文件管道,不支持非阻塞)
  • DatagramChannel
  • SocketChannel (网络管道,支持非阻塞)
  • ServerSocketChannel (服务端网络管道,支持非阻塞)

buffer 则用来缓冲读写数据,常见的 buffer 有

  • ByteBuffer
    • MappedByteBuffer
    • DirectByteBuffer
    • HeapByteBuffer
  • ShortBuffer
  • IntBuffer
  • LongBuffer
  • FloatBuffer
  • DoubleBuffer
  • CharBuffer

Selector

selector 中文就是选择器的意思,单从字面意思不好理解,需要结合服务器的设计演化来理解它的用途。服务器的设计演化从多线程->线程池selector

服务器设计历史演化

多线程版设计

在这里插入图片描述
在多线程版本下,一个请求到达服务端,服务端开辟一个线程去处理该请求,这种做法在请求量不多的情况下可以接受,但是一旦请求量多了那么问题随之而来,内存占用高、线程上下文切换成本高这些问题会让你的服务器最终崩溃。

线程池版设计

在这里插入图片描述
在线程池版本下,服务器会初始化一个线程池,池内会有一定量的线程,当请求达到服务器时会使用线程池内的线程进行处理,处理完归还给线程池。这种模式下虽然避免了服务器不停地创建线程、销毁线程,但是仍然存在问题:线程仅能处理一个 socket 连接,当处理某个socket时线程就会阻塞等待处理完成才能继续处理其他任务。

selector 版设计

在这里插入图片描述

在selector 模式下,当一个请求到达服务器时,会先和channel进行关联,由selector来管理这些channel什么时候提交给线程处理。这些 channel 工作在非阻塞模式下,有了selector就不会让线程吊死在一个 channel 上。适合连接数特别多,但流量低的场景。调用 selector 的 select() 会阻塞直到 channel 发生了读写就绪事件,这些事件发生,select 方法就会返回这些事件交给 thread 来处理。

http://www.lryc.cn/news/533885.html

相关文章:

  • pytest.fixture
  • MHTML文件如何在前端页面展示
  • 学习笔记:在华为云ModelArts上运行MindSpore扩散模型教程
  • 使用sharding-jdbc实现读写分离
  • “图像识别分割算法:解锁视觉智能的关键技术
  • 【Go语言快速上手】第二部分:Go语言进阶
  • GRN前沿:GRETA:从多模式单细胞数据推断基因调控网络方法的比较与评价
  • python基础入门:4.4模块与包管理
  • 《XSS跨站脚本攻击》
  • LC-两数之和、字母异位词分组、最长连续序列、移动零、盛最多水的容器
  • Netty源码解析之线程池的实现(二):创建线程与执行任务
  • IDEA - 一个启动类多次启动方法
  • U3D支持webgpu阅读
  • C++广度优先搜索
  • SVN 提交与原有文件类型不一样的文件时的操作
  • 活动预告 | Power Hour: Copilot 引领商业应用的未来
  • WPF 进度条(ProgressBar)示例一
  • 【C#】任务调度的实现原理与组件应用Quartz.Net
  • UV - Python 包管理
  • pytorch torch.linalg模块介绍
  • 光伏-报告显示,假期内,硅料端签单顺序发货相对稳定。若3月份下游存提产,则不排除硅料价格有上调预期。
  • 【web自动化】指定chromedriver以及chrome路径
  • 顺丰数据分析(数据挖掘)面试题及参考答案
  • Android studio:顶部导航栏Toolbar
  • mmap 文件映射
  • 基于微信小程序的医院预约挂号系统的设计与实现
  • 【Linux】Socket编程—UDP
  • 2025年物联网相关专业毕业论文选题参考,文末联系,选题相关资料提供
  • 如何在WPS和Word/Excel中直接使用DeepSeek功能
  • DeepSeek之Api的使用(将DeepSeek的api集成到程序中)