io本质+io效率本质,5种io模型(介绍,异步/同步区别,阻塞/非阻塞区别)

2024-09-07 12:36

本文主要是介绍io本质+io效率本质,5种io模型(介绍,异步/同步区别,阻塞/非阻塞区别),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

5种io模型

io引入

io的本质

io效率的本质

模型引入

以钓鱼为例

效率最高的方式

异步io和同步io的区别

阻塞式和非阻塞式io的区别

介绍

阻塞式io

​编辑

非阻塞式io

​编辑

信号驱动式io

​编辑

多路转接/复用

​编辑

异步io


5种io模型

io引入

io的本质

以read ,write为例:

  • 如果底层缓冲区没有数据/缓冲区已满,会阻塞等待
  • 网络更是如此,大部分时间都在等待,直到有数据才进行拷贝

所以,io=等待+拷贝

  • 因为上层察觉不到等待的时间,只能将等待时间也纳入io时间,无论是在等数据输入/处理数据好腾出空间,都是在等
  • 其实概括一下,等的过程就是在判断条件成立 -- 条件 : 读写事件就绪

并且,在应用层使用这两个函数,本质上是将数据在用户层和os之间传递 

  • 用户层缓冲区的数据 <---> 系统级缓冲区
  • 也就是我们之前提到的,它们本质上都是拷贝函数

io效率的本质

根据上面的内容,我们可以推出:

  • 因为高效io = 单位时间内可以拷贝更多的数据
  • 又因为拷贝工作是os做的,我们无法改变,且io=等待+拷贝
  • 所以,本质上提高io效率,就是要减少等待时间,几乎所有提高io效率的策略,都是在减少等待比重
  • 就像,我们为什么要写多线程来代替单进程, 就是因为可以把等待时间从串行->并行

模型引入

以钓鱼为例

假如a来河边钓鱼

  • 他是一个会一直关注鱼漂的人,所以在鱼咬钩之前,会一直等待,不会被外界因素打扰
  • 对应io模型中的阻塞式io,我们之前接触到的大部分接口都是这样

过了一会又来了个b

  • 他和a不一样,他闲不住,没法一直看着鱼漂,他会每隔五分钟查看一下情况,其余时间都在忙自己的(玩手机啦,看书啦等等)
  • 对应非阻塞式io(这里是轮询方式)

然后又来了个c

  • 他在鱼钩那里挂了一个铃铛,抛竿后就不管了,直到听到铃铛响才去查看
  • 对应信号驱动式io,有数据了再来通知他

富豪d也过来钓鱼

  • 他和前三个人都不一样,他开着车过来,装着一车鱼竿,然后依次把鱼竿插在地上,全部抛竿后以遍历的方式周期性检查所有鱼漂情况 -- 多路复用/转接

目前来说,d的钓鱼效率是最高的

  • 因为鱼竿数量增多,相当于增加了鱼咬钩的概率
  • 假设鱼咬任何一个鱼钩的概率是百分之一,那么d钓上鱼的概率就是n*1%,其他人都是1%

最后,大公司老板e也来钓鱼

  • 他是带着一个司机坐车过来的,他也想去钓鱼,但一会公司还有事,所以他让司机在这里钓,给他留下钓鱼工具,水桶,手机,如果钓的鱼把桶装满了就用手机通知他
  • 小王怎么钓鱼的不重要,重要的是e并没有实际参与钓鱼过程,e只是钓鱼行为的发起者,他只关心数据
  • 对应异步io -- 小王就是os,e就是发起io操作的实体(进程/线程)

例子介绍完了,接下来聊聊细节 

效率最高的方式

五种io模型中,第四种io效率最高

  • 虽然第五种自己不用参与,其实io效率没区别
  • 并且异步io写出来的服务逻辑比较混乱一些

所以,多路转接的io方式是我们最值得学习的,也是效率最高的 

异步io和同步io的区别

前四个人都属于同步io

  • 他们无论如何处理等待时间,总之都亲身参与了等待/钓的过程

最后一个则是完全没有参与

  • 只是发起io,最后拿到结果就行

这就是异步/同步的本质区别,在于是否参与io 

阻塞式和非阻塞式io的区别

也就是a和b的区别

  • 实际上两者的io效率没有区别
  • 因为io=等+拷贝,两者都没有改变等待时间的占比,只是等待的方式不同
  • 只不过b总体效率高,因为b在等待之余还做了其他事情

介绍

阻塞式io

非阻塞式io

信号驱动式io

多路转接/复用

异步io

这篇关于io本质+io效率本质,5种io模型(介绍,异步/同步区别,阻塞/非阻塞区别)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1145077

相关文章

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

MybatisPlus service接口功能介绍

《MybatisPlusservice接口功能介绍》:本文主要介绍MybatisPlusservice接口功能介绍,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录Service接口基本用法进阶用法总结:Lambda方法Service接口基本用法MyBATisP

MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)

《MySQL复杂SQL之多表联查/子查询详细介绍(最新整理)》掌握多表联查(INNERJOIN,LEFTJOIN,RIGHTJOIN,FULLJOIN)和子查询(标量、列、行、表子查询、相关/非相关、... 目录第一部分:多表联查 (JOIN Operations)1. 连接的类型 (JOIN Types)

Linux实现线程同步的多种方式汇总

《Linux实现线程同步的多种方式汇总》本文详细介绍了Linux下线程同步的多种方法,包括互斥锁、自旋锁、信号量以及它们的使用示例,通过这些同步机制,可以解决线程安全问题,防止资源竞争导致的错误,示例... 目录什么是线程同步?一、互斥锁(单人洗手间规则)适用场景:特点:二、条件变量(咖啡厅取餐系统)工作流

Mysql的主从同步/复制的原理分析

《Mysql的主从同步/复制的原理分析》:本文主要介绍Mysql的主从同步/复制的原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录为什么要主从同步?mysql主从同步架构有哪些?Mysql主从复制的原理/整体流程级联复制架构为什么好?Mysql主从复制注意

如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socket read timed out的问题

《如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socketreadtimedout的问题》:本文主要介绍解决Druid线程... 目录异常信息触发场景找到版本发布更新的说明从版本更新信息可以看到该默认逻辑已经去除总结异常信息触发场景复

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

java中BigDecimal里面的subtract函数介绍及实现方法

《java中BigDecimal里面的subtract函数介绍及实现方法》在Java中实现减法操作需要根据数据类型选择不同方法,主要分为数值型减法和字符串减法两种场景,本文给大家介绍java中BigD... 目录Java中BigDecimal里面的subtract函数的意思?一、数值型减法(高精度计算)1.

Pytorch介绍与安装过程

《Pytorch介绍与安装过程》PyTorch因其直观的设计、卓越的灵活性以及强大的动态计算图功能,迅速在学术界和工业界获得了广泛认可,成为当前深度学习研究和开发的主流工具之一,本文给大家介绍Pyto... 目录1、Pytorch介绍1.1、核心理念1.2、核心组件与功能1.3、适用场景与优势总结1.4、优

详解如何使用Python从零开始构建文本统计模型

《详解如何使用Python从零开始构建文本统计模型》在自然语言处理领域,词汇表构建是文本预处理的关键环节,本文通过Python代码实践,演示如何从原始文本中提取多尺度特征,并通过动态调整机制构建更精确... 目录一、项目背景与核心思想二、核心代码解析1. 数据加载与预处理2. 多尺度字符统计3. 统计结果可