首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

同步、异步、阻塞、非阻塞

同步与异步 同步与异步是针对应用程序与内核的交互而言的。同步过程中进程触发IO操作并等待或者轮询的去查看IO操作是否完成。...同步 同步的思想是:所有的操作都做完,才返回给用户。这样用户在线等待的时间太长,给用户一种卡死了的感觉(就是系统迁移中,点击了迁移,界面就不动了,但是程序还在执行,卡死了的感觉)。...这种情况,用户不能关闭界面,如果关闭了,即迁移程序就中断了。同步,是所有的操作都做完,才返回给用户结果。即写完数据库之后,在相应用户,用户体验不好。...阻塞 阻塞调用是指调用结果返回之前,当前线程会被挂起。函数只有在得到结果之后才会返回。有人也许会把阻塞调用和同步调用等同起来,实际上它们是不同的。...同步/异步与阻塞/非阻塞的组合 同步阻塞形式: 等待执行结果是一直等待,执行时线程挂起(未对fd 设置O_NONBLOCK 标志位的read/write 操作) 同步阻塞形式:等待执行结果是一直等待,

2.9K40

同步异步,阻塞阻塞

什么是阻塞和非阻塞 阻塞和非阻塞是针对于进程在访问数据的时候,根据IO操作的就绪状态来采取的不同方式,阻塞方式读取或者写入函数将一直等待,而非阻塞方式,读取或者写入函数会立即返回一个状态值。...同步/异步与阻塞/非阻塞的区别 同步与异步:针对数据访问的方式,程序是主动去询问操作系统数据准备好了么,还是操作系统在数据准备好的时候通知程序。...内核应用程序  同步执行,阻塞/非阻塞。用户进程/线程无法直接读写内核数据,需要数据在用户空间和内核空间搬来搬去。除非个别接口,否则一般是同步的。...可以是阻塞或非阻塞阻塞则一直在等待内核/应用程序把IO数据准备好,非阻塞则是直接返回内核/应用程序是否已经准备好数据。 应用程序框架:同步或异步。...IO多路复用,同步,异步,阻塞和非阻塞 区别 关于异步,同步阻塞与非阻塞 解读I/O多路复用技术

3.1K60
您找到你想要的搜索结果了吗?
是的
没有找到

阻塞 & 非阻塞 | 同步 & 异步

这里讲的都是基于IO的 阻塞、非阻塞同步、异步 ---- 一个典型的IO操作包括了两个阶段,数据准备和数据读写。比如说现在要使用 recv 执行一个读操作,数据就绪就是远端是否有数据可读。...当IO工作在阻塞状态的时候,如果数据没有就绪,recv就会阻塞当前线程;如果说IO工作在非阻塞状态,会立即返回。...一个同步IO接口的示例: char buf[1024]; int sz = recv(sockfd,buf,1024,0); //阻塞:一直在这儿死等 //非阻塞:时不时的回来问一 if(sz>0)...仅被 lio_listio() 函数使用 */ /* Various implementation-internal fields not shown */ }; 陈硕大神说:在处理IO的时候,阻塞和非阻塞都是同步...epoll也属于同步IO。

2.8K10

同步、异步、阻塞、非阻塞

同步、异步、阻塞和非阻塞(网络编程) 同步 所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回。 按照这个定义,其实绝大多数函数都是同步调用(例如sin, isdigit等)。...阻塞 阻塞调用是指调用结果返回之前,当前线程会被挂起。函数只有在得到结果之后才会返回。有人也许会把阻塞调用和同步调用等同起来,实际上他是不同的。...同步阻塞:小明一直盯着下载进度条,到 100% 的时候就完成。 同步阻塞:小明提交下载任务后就去干别的,每过一段时间就去瞄一眼进度条,看到 100% 就完成。...(最机智) 也就是说,同步/异步是下载软件的通知方式,或者说 API 被调用者的通知方式。阻塞/非阻塞则是小明的等待方式,或者说 API 调用者的等待方式。...在不同的场景同步/异步、阻塞/非阻塞的四种组合都有应用。

2.2K50

同步、异步、阻塞和非阻塞

同步和异步 同步:是用户线程发起IO请求需要等待或者轮询内核IO操作完成后才能继续执行。...阻塞和非阻塞 阻塞:是指IO操作需要彻底完成后才能返回用户空间。 非阻塞:是指IO操作被调用后立即返回一个状态值,无需等待IO操作完成。...同步和异步(线程间调用) 同步和异步是对应调用者和被调用者,他们是线程之间的关系,两个线程之间要么是同步的,要么是异步的。 同步操作时,调用者需要等待被调用者返回结果,才能进行下一步操作。...阻塞和非阻塞(线程内调用) 阻塞和非阻塞是对于一个线程来讲的,在任意时刻,线程要么是处于阻塞的,要么是出于非阻塞的。 阻塞和非阻塞关注的程序等待调用结果(消息,返回值)时的状态。...阻塞调用是指调用结果返回之前,当前线程会被挂起,调用线程只有在得到结果之后才会返回。 非阻塞调用是指不能立刻得到返回结果之前,该调用就不会阻塞当前线程。

2.2K40

同步异步阻塞阻塞详解

附c++代码 同步和异步 同步就是一个调用方发出请求开始,就一直处于等待状态,等待请求结果返回后才能继续执行其他任务。比如说调用一个函数,等待函数结果返回,这叫同步。...举个例子 同步与异步: 你打电话问书店老板有没有《分布式系统》这本书,如果是同步通信机制,书店老板会说,你稍等,”我查一”,然后开始查啊查,等查好了(可能是5秒,也可能是一天)告诉你结果(返回结果)...在这里阻塞与非阻塞与是否同步异步无关。跟老板通过什么方式回答你结果无关。...这时候关心的是你是否立即有答复,你是否离开了书店 c++ socket阻塞与非阻塞代码 阻塞模式的socket读取 int main(){ #创建和绑定socket,creat和bind函数...Client"); res = write(fd, buf, sizeof(buf)); printf("send data : %s\n", buf); } } 非阻塞模式

1.9K50

IO - 同步,异步,阻塞,非阻塞

同步(synchronous) IO和异步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)IO分别是什么,到底有什么区别?...所以,为了更好的回答这个问题,我先限定一本文的上下文。 本文讨论的背景是Linux环境的network IO。...blocking IO 在linux中,默认情况所有的socket都是blocking,一个典型的读操作流程大概是这样: ?...non-blocking IO linux,可以通过设置socket使其变为non-blocking。当对一个non-blocking socket执行读操作时,流程是这个样子: ?...Asynchronous I/O linux的asynchronous IO其实用得很少。先看一它的流程: ? 用户进程发起read操作之后,立刻就可以开始去做其它的事。

2.1K10

同步、异步与阻塞、非阻塞

同步与异步   同步和异步关注的是消息通信机制。同步就是在发出一个【调用】时,在没有拿到结果之前,该【调用】就不返回,但是一旦调用返回,就得到返回值了。   ...举个例子:   你打电话问书店老板有没有《分布式系统》这本书,如果是同步通信机制,书店老板会说,你稍等一,我查一,然后开始查啊查,等查好了(可能是   5秒,也可能是一天)告诉你结果(返回结果)。...总结: 同步和异步针对应用程序来说,关注的是程序中间的协作关系。   同步:执行一个操作之后,等待结果,然后才继续执行后续的操作。   ...check一老板有没有返回结果。   ...阻塞与非阻塞与是否同步异步无关。 总结: 阻塞:进程给CPU传达一个任务之后,一直在等待CPU处理完成,然后才执行后边的操作。

2.1K20

浅析同步异步阻塞阻塞

关键点: 同步和异步是与进程相关的,同步与异步主要是从消息通知机制角度来说的。阻塞和非阻塞是与线程相关的,阻塞阻塞是等待消息通知时的状态角度来说的。...同步依赖消息的同步返回,异步是通过状态,回调和通知的方式实现的。 阻塞依赖消息返回前线程挂起,不能执行其余的业务(同步只是逻辑上函数没返回,可以执行一些其余操作的)。...Linux五种IO模型: 从根本上讲I/O操作分为两部分,用户层API调用(内核);内核层完成系统调用(发起I/O请求) 所以“异步/同步”的是指API调用;“阻塞/非阻塞”是指内核完成I/O调用的模式...同步阻塞(NIO):是用户层的读或写的请求转换成内核的I/O请求,用户层同步,内核I/O非阻塞(读到返回字节,读不到返回-1)。...也就是说,同步的情况,是由处理消息者自己去等待消息是否被触发,而异步的情况是由触发机制来通知处理消息者。

1.9K80

番外:同步异步阻塞阻塞,了解一?(十三节)

]还是[ 非阻塞 ]的,异步表现在于馒头好了后,阿梅会主动告诉研究僧 总结一大概意思就是: [ 阻塞 ]和[ 非阻塞 ]在于等馒头的时候,研究僧在干什么 [ 同步 ]和[ 异步 ]在于是研究僧自己主动获取馒头状态...也就是说select\poll\epoll也是同步的,而在Linux只有AIO(PHP中的扩展叫做EIO)是异步。...既然在LinuxNginx事件是基于epoll实现的,然而上面又说了epoll这样的IO复用属于同步,那这里为什么会说[ 异步 ]非阻塞?...在Linux,指的就是AIO,唯有AIO才是真正符合定义(此处定义既指APUE中的经典异步定义)的异步!...下个章节通过代码实战来说明[ 同步阻塞 ]和[ 同步阻塞 ],AIO的咱就不碰了,有兴趣同学自己可以折磨下自己。

65231

同步、异步与阻塞、非阻塞

通常,同步操作是阻塞的,而异步操作非阻塞,但两对概念也可以交叉组合。 同步与异步是基于消息和通信的概念。...异步操作立即返回,操作完成后通知,而同步操作等待操作完成才返回(返回就相当于完成通知,也意味着没有通知)。 阻塞与非阻塞的最大区别在于,执行操作后资源是否可用(当然是否阻塞也是他们的区别)。...阻塞操作执行后资源可用,非阻塞操作执行后则不一定可用。 例如同步阻塞,执行语句后就可以做别的,但是资源不可用,没有完成通知,因此需要轮询。...异步阻塞,执行语句后不能做别的,执行下一条语句时资源已经可用了,有完成通知(异步阻塞同步阻塞只差一个通知,基本没有区别)。

1.5K10

同步异步与阻塞阻塞

| 导语 同步异步与阻塞阻塞是开发中经常碰到的概念,但是很多人都没理解清楚,或者混淆了它们的概念。最近看了一些材料,发现以前很多理解都是错的,所以重新整理了一。...同步异步与阻塞阻塞 标题有点简单粗暴,直接用了本文要介绍的几个概念。本来想取个高大上一点的标题,但是感觉主题不那么明了。 好,废话不多说,进入正题。...如果你是个研发,同步、异步、阻塞、非阻塞(还有IO多路复用)这些概念应该不陌生了。但是很多人却没有真正搞懂他们的含义,甚至经常把他们混淆了。 先上几个错误的表达提提神: 非阻塞IO模型是异步IO。...总结 前面根据概念的的讨论范围,分别介绍了与同步、异步、阻塞、非阻塞等相关的概念。其实他们也是有共通点的。 同步和异步关注的是消息的通信机制。...反之则是同步阻塞和非阻塞关注的是最终结果是否返回了。 非阻塞就是:我告诉你我要做什么,如果现在能做,那就做完再返回;如果现在还做不了,你也给我个信儿,跟我说这事儿还做不了。

1.9K230

IO - 同步,异步,阻塞,非阻塞

同步(synchronous) IO和异步(asynchronous) IO,阻塞(blocking) IO和非阻塞(non-blocking)IO分别是什么,到底有什么区别?...所以,为了更好的回答这个问题,我先限定一本文的上下文。 本文讨论的背景是Linux环境的network IO。...blocking IO 在linux中,默认情况所有的socket都是blocking,一个典型的读操作流程大概是这样: ?...non-blocking IO linux,可以通过设置socket使其变为non-blocking。当对一个non-blocking socket执行读操作时,流程是这个样子: ?...Asynchronous I/O linux的asynchronous IO其实用得很少。先看一它的流程: ? 用户进程发起read操作之后,立刻就可以开始去做其它的事。

1.8K30

准确理解阻塞、非阻塞同步、异步

有的人还会把阻塞/非阻塞同步/异步混合起来理解,认为阻塞=同步、非阻塞=异步。 那么到底是不是这样呢?这篇文章,我们就从本质上跟大家分享一这几个概念,到底应该怎么样去准确理解他们。...那在我们前端,也有这样一个类似的场景,在请求接口时,我们看一下面这两种写法: 阻塞式 const res = await api() // 阻塞式:等待 api 调用成功并有返回结果之后,才能执行后面的任务...因为这里有一个非常明显的逻辑冲突,如果我在同步模式中,老板的四次刷剧任务在哪里执行呢?是的,消失了。在这个图的同步模式里,他不是不执行别的任务,而是压根就没有别的任务。...例如,在异步模式,我有一个任务 foo 需要执行。我们这样去写代码。...api().then(res => { console.log('xxx') }) foo(); 然后呢,在同步模式,我应该怎么办呢?很简单,我们可以借助 await 来模拟。

5010

同步与异步,阻塞和非阻塞

在讲 BIO,NIO,AIO 之前,先来回顾一这样几个概念:同步与异步,阻塞与非阻塞。...同步与异步 同步同步就是发起一个调用后,被调用者未处理完请求之前,调用不返回; 异步: 异步就是发起一个调用后,立刻得到被调用者的回应,表示已接收到请求,但是被调用者并没有返回结果,此时我们可以处理其他的请求...同步和异步的最大区别,在于异步的话调用者不需要等待处理结果,被调用者会通过回调等机制来通知调用者其返回结果。...阻塞和非阻塞 阻塞阻塞就是发起一个请求,调用者一直等待请求结果返回,也就是当前线程会被挂起,无法从事其他任务,只有当条件就绪时才能继续; 非阻塞: 非阻塞就是发起一个请求,调用者不用一直等着结果返回...举个生活中简单的例子: 你妈妈让你烧水,小时候你比较笨啊,在那里傻等着水开(同步阻塞); 等你稍微长大了,你知道每次烧水的空隙可以去干点其他事,然后只需要时不时来看看水开了没有(同步阻塞); 再后来

1.1K20

IO-同步、异步、阻塞、非阻塞

,调用者不需要等待被调用者返回调用,即可进行下一步操作,被调用者通常依靠事件、回调等机制来通知调用者结果 阻塞与非阻塞(线程内调用) 阻塞与非阻塞是对同一个线程来说的,在某个时刻,线程要么处于阻塞,要么处于非阻塞...回调函数 二、同步线程与异步线程: 同步线程:即两个线程步调要一致,其中一个线程可能要阻塞等待另外一个线程的运行,要相互协商。快的阻塞等到慢的步调一致。...阻塞可以是实现同步的一种手段!例如两个东西需要同步,一旦出现不同步情况,我就阻塞快的一方,使双方达到同步同步是两个对象之间的关系,而阻塞是一个对象的状态。...四种组合方式 同步阻塞方式: 发送方发送请求之后一直等待响应。 接收方处理请求时进行的IO操作如果不能马上等到返回结果,就一直等到返回结果后,才响应发送方,期间不能进行其他工作。...同步阻塞方式: 发送方发送请求之后,一直等待响应。 接受方处理请求时进行的IO操作如果不能马上的得到结果,就立即返回,取做其他事情。

1.2K31

同步与异步 阻塞与非阻塞

1.2对应技术的问题:           我所选择的排队方式就对应同步与异步。在队伍中等待就是同步,取号等待就是异步。          ...1.3小结:      同步和异步仅仅是关于所关注的消息如何通知的机制,而不是处理消息的机制.也就是说,同步的情况,是由处理消息者自己去等待消息是否被触发,而异步的情况是由触发机制来通知处理消息者...2.同步、异步、阻塞、非阻塞的理解 2.1同步阻塞I/O      官方解释:用户空间的应用程序执行一个系统调用时,会导致应用程序阻塞。...2.2同步阻塞I/O      官方解释:      我的理解:我去银行存钱时,我不得不在队伍中排队等待,但我在等待过程中我还会打电话看书。...3.总结      同步与异步是一组相对概念,针对的是自己等待还是别人通知      阻塞和非阻塞是一组相对概念,针对的是等待过程中,等待者的操作。

1.1K20

通俗讲解 同步、异步、阻塞、非阻塞 编程

# select / poll / epoll 都是同步IO的多路复用模式 1.同步和异步 # 同步和异步关注的是消息通信机制 # 所谓同步,就是在发出一个*调用*时,没得到结果之前,该*调用*就不返回...当一个异步过程调用发出后,*被调用者*通过状态,通知来通知*调用者*,或者通过回调函数处理这个调用 2.阻塞和非阻塞 # 阻塞和非阻塞关注的是程序在等待调用结果时的状态 # 阻塞调用是指调用结果返回之前...调用线程只有在得到结果之后才返回 # 非阻塞调用是指在不能立即得到结果之前,该调用不会阻塞当前线程 通俗例子一: #老张爱喝茶 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn

35310
领券