BIO, NIO, AIO 大白话 - 澄澈大学生也能搞懂
最近天天吃沙县, 就拿沙县分析
BIO
Block I/O

- 沙县分析
相近时间来了4个顾客
| 顾客 | 菜品 | 时间 |
|---|---|---|
| A | 筒骨饭 | 5min |
| B | 茄子肉丝盖饭 | 7min |
| C | 猪脚饭 | 3min |
| D | 茄子肉丝盖饭 | 7min |
老板只能按照顺序 5+7+3+7 = 22分钟完工
每次做完一个菜, 还要问下一个顾客点的是什么(一心不能二用, 记不住<顾客, 菜品>键值对)
NIO
non-blocking I/O
服务端运行多个客户端发送消息, 不会阻塞

- 沙县分析
相近时间来了4个顾客
| 顾客 | 菜品 | 时间 |
|---|---|---|
| A | 筒骨饭 | 5min |
| B | 茄子肉丝盖饭 | 7min |
| C | 猪脚饭 | 3min |
| D | 茄子肉丝盖饭 | 7min |
每一个handler(锅)只能处理一个菜品(可能要求比较高的饭店, 怕串味)
时间为 7+7 = 14分钟完工
多路复用
每个handler(锅)可以处理任何菜品(高效出餐)
时间为 Math.min(5, 7 ,3) + 7 = 10分钟完工
单线程+队列下的<伪>NIO
没有block的IO就是NIO
我们学校附近的沙县属于小本生意, 只有老板和和老板娘
人多的时候老板娘负责记菜, 老板负责炒菜

- 沙县分析
每次顾客等的有点急了, 老板娘都安慰说<在炒了>
那我们也不知道在没在炒, 万一真在炒了,还是等一下吧
如果是BIO, 那有没有炒就一目了然了
AIO
Asynchronous I/O 异步IO
我们在NIO中引入了分发器和处理器的关系
而AIO就是优化了分发器和处理器

- 沙县分析
后厨对应内核区, 老板娘对应分发器, 我们对应处理器(处理食物)
那我们天天去吃, 跟老板娘也熟了,跟老板娘要了电话号码
我们要吃的时候, 跟老板娘说要两份, 放在3号桌
老板娘说做好了, 我们马上跑到3号桌, 处理食物
BIO, NIO, AIO 大白话 - 澄澈大学生也能搞懂的更多相关文章
- (转)也谈BIO | NIO | AIO (Java版)
原文地址: https://my.oschina.net/bluesky0leon/blog/132361 关于BIO | NIO | AIO的讨论一直存在,有时候也很容易让人混淆,就我的理解,给出一 ...
- 拿搬东西来解释udp tcpip bio nio aio aio异步
[群主]雷欧纳德简单理解 tcpip是有通信确认的面对面通信 有打招呼的过程 有建立通道的过程 有保持通道的确认 有具体传输udp是看到对面的人好像在对面等你 就往对面扔东西[群主]雷欧 ...
- 也谈BIO | NIO | AIO (Java版--转)
关于BIO | NIO | AIO的讨论一直存在,有时候也很容易让人混淆,就我的理解,给出一个解释: BIO | NIO | AIO,本身的描述都是在Java语言的基础上的.而描述IO,我们需要从两个 ...
- IO回忆录之怎样过目不忘(BIO/NIO/AIO/Netty)
有热心的网友加我微信,时不时问我一些技术的或者学习技术的问题.有时候我回微信的时候都是半夜了.但是我很乐意解答他们的问题.因为这些年轻人都是很有上进心的,所以在我心里他们就是很优秀的,我愿意多和努力的 ...
- Netty5序章之BIO NIO AIO演变
Netty5序章之BIO NIO AIO演变 Netty是一个提供异步事件驱动的网络应用框架,用以快速开发高性能.高可靠的网络服务器和客户端程序.Netty简化了网络程序的开发,是很多框架和公司都在使 ...
- I/O模型系列之三:IO通信模型BIO NIO AIO
一.传统的BIO 网络编程的基本模型是Client/Server模型,也就是两个进程之间进行相互通信,其中服务端提供位置信息(绑定的IP地址和监听端口),客户端通过连接操作向服务端监听的地址发起连接请 ...
- 【netty】(1)---BIO NIO AIO演变
BIO NIO AIO演变 Netty是一个提供异步事件驱动的网络应用框架,用以快速开发高性能.高可靠的网络服务器和客户端程序.Netty简化了网络程序的开发,是很多框架和公司都在使用的技术. Net ...
- Netty序章之BIO NIO AIO演变
Netty序章之BIO NIO AIO演变 Netty是一个提供异步事件驱动的网络应用框架,用以快速开发高性能.高可靠的网络服务器和客户端程序.Netty简化了网络程序的开发,是很多框架和公司都在使用 ...
- java BIO/NIO/AIO 学习
一.了解Unix网络编程5种I/O模型 1.1.阻塞式I/O模型 阻塞I/O(blocking I/O)模型,进程调用recvfrom,其系统调用直到数据报到达且被拷贝到应用进程的缓冲区中或者发生错误 ...
- BIO | NIO | AIO (Java版)
几篇解释的不错的文章: BIO NIO AIO NIO.2 入门,第 1 部分: 异步通道 API 使用异步 I/O 大大提高应用程序的性能
随机推荐
- 网站支持https之一:https原理和SSL证书类型
1 https原理 https加密请求过程 Client和Server之间会进行一下几个步骤的交互: ① Client发送https请求: ② Client和Server通过tcp的三次握手建立连接, ...
- 探秘Transformer系列之(16)--- 资源占用
探秘Transformer系列之(16)--- 资源占用 目录 探秘Transformer系列之(16)--- 资源占用 文章总表 0x00 概述 0x01 背景知识 1.1 数据类型 1.2 进制& ...
- Delphi WebBrowser内核版本修改D7
private { Private declarations } public { Public declarations } function WriteAppNameToReg:Boolean; ...
- md语法练手随笔
代码 单行代码:代码之间分别用一个反引号包起来 代码块: 代码之间分别用三个反引号包起来, 且两边的反引号单独占一行 这是一级标题 这是六级标题 这是加粗的文字 这是倾斜的文字 这是斜体加粗的文字 这 ...
- STM32 调试小结
图片1相关内容 确认芯片连接 使用keil软件打开一个STM32工程文档,编译,无报错 点击魔术棒,弹出配置界面"option for target XXXXX" 点击配置界面的D ...
- spring基于xml创建bean对象
一.导入JAR包 二.配置applicationContext.xml的spring核心配置 三. public static void main(String[] args) { //1.使用 Ap ...
- 华为od机考2025A卷真题 -寻找重复代码
题目描述与示例 题目 小明负责维护项目下的代码,需要查找出重复代码,用以支撑后续的代码优化,请你帮助小明找出重复的代码. 重复代码查找方法:以字符串形式给出两行代码text1,text2(字符串长度1 ...
- Python—Pytorch学习-RNN(一)
前言 有好几个月没搞神经网络代码了,期间也就是回顾了两边之前的文字. 不料,对nn,cnn的理解反而更深入了-_-!. 修改 <零基础学习人工智能-Python-Pytorch学习(四)> ...
- EFCore 高并发
EFCore 高并发 有常见的并发场景?如果我们使用EFCore常用的解决方法会出现哪些问题?对应不同的并发场景我们应该选择哪些的处理方式? 参照:事务的四种隔离级别详解_事务隔离级别-CSDN博客 ...
- EF Core Demo1——初识DbContext
EF中的上下文(DbContext)简介 DbContext是实体类和数据库之间的桥梁,DbContext主要负责与数据交互,主要作用: 1.DbContext包含所有的实体映射到数据库表的实体集 ...