同步异步 阻塞非阻塞

news2024/11/20 4:39:41

同步/异步 阻塞/非阻塞

IO一般有两个阶段:数据就绪和数据读写。

数据就绪:根据系统IO操作的就绪状态。

  • 阻塞
  • 非阻塞

数据读写:根据应用程序和内核的交互方式。

  • 同步
  • 异步

在这里插入图片描述

陈硕:在处理IO的时,阻塞和非阻塞都是同步IO,只有使用了特殊的API才是异步IO。

一个典型的网络IO接口调用,分为两个阶段,分别是“数据就绪” 和 “数据读写”,数据就绪阶段分为
阻塞和非阻塞,表现得结果就是,阻塞当前线程或是直接返回

同步表示A向B请求调用一个网络IO接口时(或者调用某个业务逻辑API接口时),数据的读写都是
由请求方A自己来完成的(不管是阻塞还是非阻塞);异步表示A向B请求调用一个网络IO接口时
(或者调用某个业务逻辑API接口时),向B传入请求的事件以及事件发生时通知的方式,A就可以
处理其它逻辑了,当B监听到事件处理完成后,会用事先约定好的通知方式,通知A处理结果。


比如IO读取数据分为两个阶段,第一个阶段是内核准备好数据,第二个阶段是内核把数据从内核态拷贝到用户态。

  • 阻塞IO是当用户调用 read 后,用户线程会被阻塞,等内核数据准备好并且数据从内核缓冲区拷贝到用户态缓存区后, read 才会返回。阻塞IO是两个阶段都会阻塞,没有数据时也会阻塞。

  • 非阻塞IO是调用read后,如果没有数据就立马返回,通过不断轮询的方式去调用read,直到数据被拷贝到用户态的应用程序缓冲区,read请求才获取到结果。非阻塞IO阻塞的是第二个阶段,第一阶段没有数据时不会阻塞,第二阶段等待内核把数据从内核态拷贝到用户态的过程中才会阻塞。

  • 同步 IO是应用程序发起一个 IO 操作后,必须等待内核把 IO 操作处理完成后才返回。无论 read 是阻塞 I/O,还是非阻塞 I/O, 都是同步调用,因为在 read 调用时,第二阶段内核将数据从内核空间拷贝到用户空间的过程都是需要等待的。

  • 异步 IO应用程序发起一个 IO 操作后,调用者不能立刻得到结果,而是在内核完成 IO 操作后,通过信号或回调来通知调用者。异步 I/O 是内核数据准备好和数据从内核态拷贝到用户态这两个过程都不用等待。

总结一下,只有同步才有阻塞和非阻塞之分,异步必定是非阻塞的。

只有用户线程在操作IO的时候根本不去考虑IO的执行,全部都交给内核去完成,而自己只等待一个完成信号的时候,才是真正的异步IO。select、poll、epool等IO多路复用方式都是同步的。


lect、poll、epool`等IO多路复用方式都是同步的。


参考视频:牛客 『面试问答』:阻塞、非阻塞、同步和异步IO的区别是什么

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1154790.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

光伏储能充电桩一体化能量管理系统-安科瑞黄安南

一.背景与需求 随着全球能源危机、用能增加以及新能源技术的增加,新能源发电越来越广,并逐步形成新型能源与电力市场,但新能源的能量密度普遍偏低,进行大功率发电还需要挑选适合的位置场地,因此属于间歇式电源。而微电…

Python与Pycharm的安装与使用

1. Python下载与安装 python官网:链接 Python下载:各版本下载链接 1.1 Python下载 1、首先进入下载页面,选择一个版本下载,这里以Python3.7为例 2、点击下载,随后得到对应安装包 1.2 Python安装 1、双击进行软件…

【漏洞复现】锐捷RG-EW1200G登录绕过

漏洞描述 免责声明 技术文章仅供参考,任何个人和组织使用网络应当遵守宪法法律,遵守公共秩序,尊重社会公德,不得利用网络从事危害国家安全、荣誉和利益,未经授权请勿利用文章中的技术资料对任何计算机系统进行入侵操作…

Android开发知识学习——Kotlin进阶

文章目录 次级构造主构造器init 代码块构造属性data class相等性解构Elvis 操作符when 操作符operatorLambdainfix 函数嵌套函数注解使用处目标函数简化函数参数默认值扩展函数类型内联函数部分禁用用内联具体化的类型参数抽象属性委托属性委托类委托 Kotlin 标准函数课后题 次…

Linux进程程序替换

一、单进程下的程序替换 使用execl进行程序替换,先执行execl前面的代码,在execl处替换成其它进程的代码和数据继续执行,后面的内容就不执行了,因此只打印before 二、程序替换原理 前面我们fork创建子进程,子进程会继承…

每日一题(LeetCode)----二分查找(三)

每日一题(LeetCode)----二分查找(三) 1.题目(69. x 的平方根 ) 给你一个非负整数 x ,计算并返回 x 的 算术平方根 。 由于返回类型是整数,结果只保留 整数部分 ,小数部分将被 舍去 。 **注意…

安防视频汇聚平台EasyCVR调用播放接口的详细流程

视频云存储/安防监控EasyCVR视频汇聚平台基于云边端智能协同,支持海量视频的轻量化接入与汇聚、转码与处理、全网智能分发、视频集中存储等。流媒体视频平台EasyCVR拓展性强,视频能力丰富,具体可实现视频监控直播、视频轮播、视频录像、云存储…

如何优雅的开发?低代码搭建应用如此轻松

目录 一、前言 二、低代码平台体验简述 三、关于平台 四、场景及用户分析 五、产品分析 1、着重讲一下JNPF的编辑器 2、业务流程 六、最后,说些心里话 一、前言 低代码平台改变了应用交付和管理的模式,大幅缩减交付周期,最终帮助业务…

悠络客荣膺CPSE安博会最高荣誉——金鼎奖

10月24日,第十九届CPSE安博会金鼎奖、百强工程商颁奖典礼暨欢迎晚宴在深圳隆重举行。经过专业评审团队对产品的品质、性能、市场表现、应用价值等多方面因素的权威评估,第十九届CPSE安博会最高荣誉奖“金鼎奖”获奖名单正式揭晓。 悠络客UMind-智慧零售/…

3D虚拟样板间场景制作软件的应用优势及价值

高端家装样板间不仅代表着高品质的家居生活,还是一种生活态度和品味的体现。为了让客户能够更好地体验到高端家装样板间的魅力,许多家装公司和房地产开发商开始尝试使用VR技术来进行样板间的拍摄和展示。通过VR全景拍摄,客户可以在线上进行参…

高效处理大规模数据集的概率型数据结构—— 布隆过滤器 [C++入门]

阅读导航 引言一、布隆过滤器提出二、布隆过滤器的概念三、布隆过滤器的实现1. 插入2. 查找3. 删除(不支持)C模拟实现布隆过滤器 四、布隆过滤器的优缺点✅优点✅缺点 引言 🍔在上一篇文章位图中,我们了解了C中位图的概念和实现。…

动作捕捉系统输出四元数、欧拉角数据

四元数和欧拉角是进行无人机、无人车、机器人等相关实验中经常需要获取的数据。NOKOV度量动作捕捉系统支持实时获取数据,也支持采集导出数据。 一、创建刚体 1、在场地中间放置被测物,这时被测物显示在形影软件界面中。 2、在形影软件界面左上角点击“…

银河集团香港优才计划95分获批案例展示!看看是如何申请的?

银河集团香港优才计划95分获批案例展示!看看是如何申请的? 今天来分享一则银河集团香港优才计划获批案例!客户本科学历非名校、从事业务支援及人力资源行业,优才打分95分,这个条件可能在很多人的印象里,会觉…

C语言实现从键盘输入一个正整数,判断他们是否是回文数,所谓回文数,是指正数和反数都一样例如 123321 是回文数

完整代码&#xff1a; /*从键盘输入一个正整数&#xff0c;判断他们是否是回文数&#xff0c;所谓回文数&#xff0c;是指正数和反数都一样 例如 123321 是回文数*/ #include<stdio.h> //这个数的最大长度 #define N 10 int main(){//length是这个数的长度int num,lengt…

CDN加速技术海外与大陆优劣势对比

内容分发网络&#xff08;CDN&#xff09;是一项广泛应用于网络领域的技术&#xff0c;旨在提高网站和应用程序的性能、可用性和安全性。CDN是一种通过将内容分发到全球各地的服务器来加速数据传输的服务。本文将探讨使用CDN的优势以及国内CDN和海外CDN之间的不同优势和劣势。 …

智能化管理大规模电脑文件的高效方法

在现代社会中&#xff0c;电脑已经成为我们生活和工作中必不可少的工具。随着时间的推移&#xff0c;我们电脑中的文件越来越多&#xff0c;管理起来也变得越来越困难。为了提高工作效率&#xff0c;我们需要学会高效管理电脑文件。下面&#xff0c;我将分享一些在线分享批量智…

Mysql5.7安装配置详细图文教程(msi版本)

博主介绍&#xff1a;✌全网粉丝5W&#xff0c;全栈开发工程师&#xff0c;从事多年软件开发&#xff0c;在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战&#xff0c;博主也曾写过优秀论文&#xff0c;查重率极低&#xff0c;在这方面有丰富的经验…

超级账本区块链Fabric2.4.4版本搭建过程(完整过程)

前提环境:乌班图20.04环境 安装所需要的工具 先配置一下代理源为阿里云代理&#xff1a; sudo apt-get update 更新源 sudo apt-get install ssh 安装远程客户端 sudo apt-get install curl 安装命令行工具 sudo apt-get install git 安装git sudo apt-get install gcc 安装…

C语言之用指针交换两个数

1.指针存放是是地址&#xff0c;所以在用指针交换两个数的时候&#xff0c;需要对指针进行解引用(*p)。 用指针交换两个数&#xff0c;需要知道p1p2与*p1*p2。 p1p1是将p2的值赋值给p1. *p1*p2是将p2指针地址存放的值&#xff0c;赋值给p1指针地址存放的值&#xff0c;即p1地…