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

同步异步阻塞阻塞

同步异步 同步异步是针对应用程序与内核的交互而言的。同步过程中进程触发IO操作并等待或者轮询的去查看IO操作是否完成。...阻塞阻塞   应用进程请求I/O操作时,如果数据未准备好,如果请求立即返回就是非阻塞,不立即返回就是阻塞。简单说就是做一件事如果不能立即获得返回,需要等待,就是阻塞,否则就可以理解为阻塞。...阻塞 阻塞阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会阻塞当前线程,而会立刻返回。...同步/异步阻塞/阻塞的组合 同步阻塞形式: 等待执行结果是一直等待,执行时线程挂起(未对fd 设置O_NONBLOCK 标志位的read/write 操作) 同步阻塞形式:等待执行结果是一直等待,...异步阻塞形式:在处理消息是不等待,在执行消息是也不等待。

3K40
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    同步异步阻塞阻塞

    同步/异步阻塞/阻塞的区别 同步异步:针对数据访问的方式,程序是主动去询问操作系统数据准备好了么,还是操作系统在数据准备好的时候通知程序。...所以这一步是异步的。 内核应用程序  同步执行,阻塞/阻塞。用户进程/线程无法直接读写内核数据,需要数据在用户空间和内核空间搬来搬去。除非个别接口,否则一般是同步的。...可以是阻塞阻塞阻塞则一直在等待内核/应用程序把IO数据准备好,阻塞则是直接返回内核/应用程序是否已经准备好数据。 应用程序框架:同步异步。...框架若使用异步IO,则通常需要应用程序内核之间是非阻塞的。一旦内核应用程序数据IO完成,则执行回调函数,执行一定的操作。 参考文章: 怎样理解阻塞阻塞同步异步的区别?...IO多路复用,同步异步阻塞阻塞 区别 关于异步同步阻塞阻塞 解读I/O多路复用技术

    3.2K60

    阻塞 & 阻塞 | 同步 & 异步

    这里讲的都是基于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的时候,阻塞阻塞都是同步...---- 五种IO模型 阻塞阻塞: 多路IO复用 信号驱动: 这里就完全放飞自我了 异步: ---- Reactor反应堆模型 One loop per thread

    2.9K10

    同步异步阻塞阻塞

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

    2.2K50

    同步异步阻塞阻塞

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

    2.2K40

    同步异步阻塞阻塞详解

    附c++代码 同步异步 同步就是一个调用方发出请求开始,就一直处于等待状态,等待请求结果返回后才能继续执行其他任务。比如说调用一个函数,等待函数结果返回,这叫同步。...阻塞阻塞 对于阻塞阻塞,其实更关心的是进程的状态,如果函数返回结果之前,主进程被挂起,也就是处于阻塞状态,那这时候整个过程是阻塞的;如果结果返回之前,主进程状态是非阻塞的,那整个过程是非阻塞。...举个例子 同步异步: 你打电话问书店老板有没有《分布式系统》这本书,如果是同步通信机制,书店老板会说,你稍等,”我查一下”,然后开始查啊查,等查好了(可能是5秒,也可能是一天)告诉你结果(返回结果)...这时候关心的是你是否在等待结果,有没有不管这件事 阻塞阻塞: 你打电话问书店老板有没有《分布式系统》这本书,你如果是阻塞式调用,你会一直把自己“挂起”,直到得到这本书有没有的结果,如果是非阻塞式调用...在这里阻塞阻塞与是否同步异步无关。跟老板通过什么方式回答你结果无关。

    2K50

    同步异步阻塞阻塞

    同步异步   同步异步关注的是消息通信机制。同步就是在发出一个【调用】时,在没有拿到结果之前,该【调用】就不返回,但是一旦调用返回,就得到返回值了。   ...总结: 同步异步针对应用程序来说,关注的是程序中间的协作关系。   同步:执行一个操作之后,等待结果,然后才继续执行后续的操作。   ...异步:执行一个操作之后,可以去执行其他操作,然后等待通知再回来执行刚才没执行完的操作。 1. 阻塞阻塞   阻塞阻塞关注的是程序在等待调用结果(消息,返回值)时的状态。   ...阻塞调用是指调用结果返回之前,当前线程会被挂起,调用线程只有在得到结果之后才会返回。   阻塞调用指在不能立刻得到结果之前,该调用不会阻塞当前线程。   ...阻塞阻塞与是否同步异步无关。 总结: 阻塞:进程给CPU传达一个任务之后,一直在等待CPU处理完成,然后才执行后边的操作。

    2.1K20

    浅析同步异步阻塞阻塞

    关键点: 同步异步是与进程相关的,同步异步主要是从消息通知机制角度来说的。阻塞阻塞是与线程相关的,阻塞阻塞是等待消息通知时的状态角度来说的。...在这里我们每一个办理业务的人相当于一个进程,这就是同步异步阻塞阻塞: 如果上面排队和取号之后,我们什么都不做,只是等待通知到我们去办理业务,那就是阻塞的。...同步阻塞(NIO):是用户层的读或写的请求转换成内核的I/O请求,用户层同步,内核I/O阻塞(读到返回字节,读不到返回-1)。...信号驱动式IO:为异步阻塞的一种,把上述的订阅I/O事件,转换成用信号驱动的方式实现。 异步阻塞(AIO):用户层的读或写的请求转换成内核的I/O请求,用户层异步,内核I/O阻塞。...总结:同步异步仅仅是关注的消息如何通知的机制,而阻塞阻塞关注的是等待消息通知时的状态。

    2K80

    同步异步阻塞阻塞

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

    1.9K230

    同步异步阻塞阻塞

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

    1.5K10

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

    有的人还会把阻塞/阻塞同步/异步混合起来理解,认为阻塞=同步阻塞=异步。 那么到底是不是这样呢?这篇文章,我们就从本质上跟大家分享一下这几个概念,到底应该怎么样去准确理解他们。...0 阻塞/阻塞 首先我们要明确的第一个概念是:阻塞/阻塞是一种现象,这是一个相对概念。 例如我们去医院看病。当你挂号之后,发现前面还有人在排队等待。那么前面的人,对于你而言,都是阻塞任务。...在实现的过程中,我们约定的任务执行顺序、任务优先级、当前的任务数量等综合因素,造成了阻塞阻塞的结果。...因此,我们学习的时候,重点不应该放在阻塞/阻塞的概念上,而是应该去关注任务执行顺序和任务优先级的约定。阻塞/阻塞只是在描述一个现象,一个结果。...1 同步异步 事实上,中文互联网环境里,有大量的文章和观点对同步的理解是如下图这种的模式。 这个例子中,老板交给你任务之后,就一直等待,什么都不做,等你做完之后才继续下一个任务。

    10510

    同步异步阻塞阻塞

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

    1.2K20

    同步异步 阻塞阻塞

    2.同步异步阻塞阻塞的理解 2.1同步阻塞I/O      官方解释:用户空间的应用程序执行一个系统调用时,会导致应用程序阻塞。...2.2同步阻塞I/O      官方解释:      我的理解:我去银行存钱时,我不得不在队伍中排队等待,但我在等待过程中我还会打电话看书。...2.3异步阻塞I/O      官方解释:另外一个阻塞解决方案是带有阻塞通知的阻塞 I/O。...2.4 异步阻塞I/O(AIO)      官方解释:异步阻塞 I/O 模型是一种处理与 I/O 重叠进行的模型。读请求会立即返回,说明 read 请求已经成功发起了。...3.总结      同步异步是一组相对概念,针对的是自己等待还是别人通知      阻塞阻塞是一组相对概念,针对的是等待过程中,等待者的操作。

    1.2K20

    IO-同步异步阻塞阻塞

    ,调用者不需要等待被调用者返回调用,即可进行下一步操作,被调用者通常依靠事件、回调等机制来通知调用者结果 阻塞阻塞(线程内调用) 阻塞阻塞是对同一个线程来说的,在某个时刻,线程要么处于阻塞,要么处于阻塞...阻塞调用指在不能立刻得到结果之前,该调用不会阻塞当前线程。...回调函数 二、同步线程与异步线程: 同步线程:即两个线程步调要一致,其中一个线程可能要阻塞等待另外一个线程的运行,要相互协商。快的阻塞一下等到慢的步调一致。...同步阻塞方式: 发送方发送请求之后,一直等待响应。 接受方处理请求时进行的IO操作如果不能马上的得到结果,就立即返回,取做其他事情。...(实际不应用) 异步阻塞方式: 发送方向接收方请求后,不等待响应,可以继续其他工作。 接收方处理请求时进行IO操作如果不能马上得到结果,也不等待,而是马上返回去做其他事情。

    1.3K31

    深入理解--异步阻塞同步阻塞异步阻塞

    异步阻塞的概念实际上已经出现了很长一段时间。但是异步真正开始流行起来,是因为AJAX技术逐渐成为主流的web开发技术。...同步异步阻塞阻塞这几个概念相互之间联系紧密,很难区分。很多程序员都不知道它们之间的具体的不同。...本文就会详细讨论这个问题,希望能帮助读者更好的了解这几个概念 同步阻塞 首先,我们先开始介绍与异步阻塞对立的两个概念:同步阻塞 对于web开发者来说,理解同步的概念相对比较容易,因为HTTP协议就是一个同步的协议...这通常会造成性能的瓶颈,因为这个方法会阻塞,导致无法继续执行随后的操作。 异步阻塞 异步阻塞就是同步阻塞的相反面。...这里说的更详细一点就是,我们知道底层数据准备好之后,还要从内核区域拷贝到线程的缓冲区,阻塞操作在这种意义上来说,又是同步的,因为阻塞不会将这个拷贝数据的过程完成,而是当数据准备好了,告诉线程,你可以执行系统调用

    1K40

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

    # 真正意义上的 异步IO 是说内核直接将数据拷贝至用户态的内存单元,再通知程序直接去读取数据。...# select / poll / epoll 都是同步IO的多路复用模式 1.同步异步 # 同步异步关注的是消息通信机制 # 所谓同步,就是在发出一个*调用*时,没得到结果之前,该*调用*就不返回...但是一旦调用返回就得到返回值了,*调用者*主动等待这个*调用*的结果 # 所谓异步,就是在发出一个*调用*时,这个*调用*就直接返回了,不管返回有没有结果。...当一个异步过程调用发出后,*被调用者*通过状态,通知来通知*调用者*,或者通过回调函数处理这个调用 2.阻塞阻塞 # 阻塞阻塞关注的是程序在等待调用结果时的状态 # 阻塞调用是指调用结果返回之前...调用线程只有在得到结果之后才返回 # 阻塞调用是指在不能立即得到结果之前,该调用不会阻塞当前线程 通俗例子一: #老张爱喝茶 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn

    37310
    领券