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

同步、异步阻塞阻塞

阻塞阻塞   应用进程请求I/O操作时,如果数据未准备好,如果请求立即返回就是非阻塞,不立即返回就是阻塞。简单说就是做一件事如果不能立即获得返回,需要等待,就是阻塞,否则就可以理解为阻塞。...阻塞 阻塞阻塞的概念相对应,指在不能立刻得到结果之前,该函数不会阻塞当前线程,而会立刻返回。...同步/异步阻塞/阻塞的组合 同步阻塞形式: 等待执行结果是一直等待,执行时线程挂起(未对fd 设置O_NONBLOCK 标志位的read/write 操作) 同步阻塞形式:等待执行结果是一直等待,...执行时函数立即返回(对fd 设置O_NONBLOCK 标志位的read/write 操作) 异步阻塞形式:不是在处理消息时一直等待(通过状态、通知,或回调函数通知主调函数select ),而是在等待消息被触发时被阻塞...异步阻塞形式:在处理消息是不等待,在执行消息是也不等待。

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

    同步异步阻塞阻塞

    什么是阻塞阻塞 阻塞阻塞是针对于进程在访问数据的时候,根据IO操作的就绪状态来采取的不同方式阻塞方式下读取或者写入函数将一直等待,而非阻塞方式下,读取或者写入函数会立即返回一个状态值。...同步/异步阻塞/阻塞的区别 同步与异步:针对数据访问的方式,程序是主动去询问操作系统数据准备好了么,还是操作系统在数据准备好的时候通知程序。...阻塞阻塞:针对函数(程序)运行的方式,在IO未就绪时,是等待就绪还是直接返回(执行别的操作)。...阻塞阻塞的区别: 阻塞是程序在调用系统函数IO时,在系统执行系统调用时由CPU通过轮询等方式来实现数据的IO。 阻塞是在程序级别通过轮询/信号/事件的机制,去查看IO数据是否就绪。...IO多路复用,同步,异步阻塞阻塞 区别 关于异步,同步,阻塞阻塞 解读I/O多路复用技术

    3.1K60

    阻塞 & 阻塞 | 同步 & 异步

    这里讲的都是基于IO的 阻塞阻塞、同步、异步 ---- 一个典型的IO操作包括了两个阶段,数据准备和数据读写。比如说现在要使用 recv 执行一个读操作,数据就绪就是远端是否有数据可读。...当IO工作在阻塞状态下的时候,如果数据没有就绪,recv就会阻塞当前线程;如果说IO工作在阻塞状态下,会立即返回。...返回值-1的话,就说明连接出现问题,连接异常;如果返回值是0,且errno是EAGIN的话,就说明这是一个正常的阻塞,返回数据未就绪状态。...如果是异步,在传入sockfd和buf之外,还要传入通知方式,告诉操作系统的异步IO负责监听这个sockfd是否有数据可读,如果有,有操作系统将数据拷贝到buf中,并通知应用程序。...---- 五种IO模型 阻塞阻塞: 多路IO复用 信号驱动: 这里就完全放飞自我了 异步: ---- Reactor反应堆模型 One loop per thread

    2.9K10

    同步、异步阻塞阻塞

    同步、异步阻塞阻塞(网络编程) 同步 所谓同步,就是在发出一个功能调用时,在没有得到结果之前,该调用就不返回。 按照这个定义,其实绝大多数函数都是同步调用(例如sin, isdigit等)。...阻塞对象上可以有阻塞的调用方式,我们可以通过一定的API去轮询状态,在适当的时候调用阻塞函数,就可以避免阻塞。而对于阻塞对象,调用特殊的函数也可以进入阻塞调用。...不过小明仍然一直等待“叮”的声音(看起来很傻,不是吗)最蠢 异步阻塞:仍然是那个会“叮”一声的下载软件,小明提交下载任务后就去干别的,听到“叮”的一声就知道完成了。...(最机智) 也就是说,同步/异步是下载软件的通知方式,或者说 API 被调用者的通知方式阻塞/阻塞则是小明的等待方式,或者说 API 调用者的等待方式。...在不同的场景下,同步/异步阻塞/阻塞的四种组合都有应用。

    2.2K50

    同步、异步阻塞阻塞

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

    2.2K40

    同步异步阻塞阻塞详解

    阻塞阻塞 对于阻塞阻塞,其实更关心的是进程的状态,如果函数返回结果之前,主进程被挂起,也就是处于阻塞状态,那这时候整个过程是阻塞的;如果结果返回之前,主进程状态是非阻塞的,那整个过程是非阻塞。...而异步通信机制,书店老板直接告诉你我查一下啊,查好了打电话给你,然后直接挂电话了(不返回结果)。然后查好了,他会主动打电话给你。在这里老板通过“回电”这种方式来回调。...这时候关心的是你是否在等待结果,有没有不管这件事 阻塞阻塞: 你打电话问书店老板有没有《分布式系统》这本书,你如果是阻塞式调用,你会一直把自己“挂起”,直到得到这本书有没有的结果,如果是非阻塞式调用...在这里阻塞阻塞与是否同步异步无关。跟老板通过什么方式回答你结果无关。...这时候关心的是你是否立即有答复,你是否离开了书店 c++ socket阻塞阻塞代码 阻塞模式下的socket读取 int main(){ #创建和绑定socket,creat和bind函数

    2K50

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

    异步阻塞的概念实际上已经出现了很长一段时间。但是异步真正开始流行起来,是因为AJAX技术逐渐成为主流的web开发技术。...同步 ,异步阻塞阻塞这几个概念相互之间联系紧密,很难区分。很多程序员都不知道它们之间的具体的不同。...本文就会详细讨论这个问题,希望能帮助读者更好的了解这几个概念 同步和阻塞 首先,我们先开始介绍与异步阻塞对立的两个概念:同步和阻塞 对于web开发者来说,理解同步的概念相对比较容易,因为HTTP协议就是一个同步的协议...这通常会造成性能的瓶颈,因为这个方法会阻塞,导致无法继续执行随后的操作。 异步阻塞 异步阻塞就是同步和阻塞的相反面。...通常来说,系统调用会进入内核,一般都是阻塞的,所以read操作往往是阻塞的,会等待可用数据,并且将线程休眠。 现在,我们应该对于异步阻塞的概念已经有所了解了。

    1K40

    浅析同步异步阻塞阻塞

    关键点: 同步和异步是与进程相关的,同步与异步主要是从消息通知机制角度来说的。阻塞阻塞是与线程相关的,阻塞阻塞是等待消息通知时的状态角度来说的。...同步依赖消息的同步返回,异步是通过状态,回调和通知的方式实现的。 阻塞依赖消息返回前线程挂起,不能执行其余的业务(同步只是逻辑上函数没返回,可以执行一些其余操作的)。...在这里我们每一个办理业务的人相当于一个进程,这就是同步与异步阻塞阻塞: 如果上面排队和取号之后,我们什么都不做,只是等待通知到我们去办理业务,那就是阻塞的。...信号驱动式IO:为异步阻塞的一种,把上述的订阅I/O事件,转换成用信号驱动的方式实现。 异步阻塞(AIO):用户层的读或写的请求转换成内核的I/O请求,用户层异步,内核I/O阻塞。...不过这种只是看上去很美,Java里的实现方式还是NIO的一套东西。 总结:同步和异步仅仅是关注的消息如何通知的机制,而阻塞阻塞关注的是等待消息通知时的状态。

    2K80

    同步、异步阻塞阻塞

    异步通信机制,书店老板直接告诉你我查一下啊,查好了打电话给你,然后直接挂了电话(不返回结果),然后查好了,他会主动打电话给你。在这里   老板通过这种方式来回调。...异步:执行一个操作之后,可以去执行其他操作,然后等待通知再回来执行刚才没执行完的操作。 1. 阻塞阻塞   阻塞阻塞关注的是程序在等待调用结果(消息,返回值)时的状态。   ...阻塞调用是指调用结果返回之前,当前线程会被挂起,调用线程只有在得到结果之后才会返回。   阻塞调用指在不能立刻得到结果之前,该调用不会阻塞当前线程。   ...阻塞阻塞与是否同步异步无关。 总结: 阻塞:进程给CPU传达一个任务之后,一直在等待CPU处理完成,然后才执行后边的操作。   ...阻塞:进程给CPU传达一个任务之后,继续处理后续的操作,隔段时间再来询问之前的操作是否完成,这样的机制也叫轮询。

    2.1K20

    同步、异步阻塞阻塞

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

    1.5K10

    同步异步阻塞阻塞

    如果你是个研发,同步、异步阻塞阻塞(还有IO多路复用)这些概念应该不陌生了。但是很多人却没有真正搞懂他们的含义,甚至经常把他们混淆了。 先上几个错误的表达提提神: 阻塞IO模型是异步IO。...IO多路复用模型是异步IO。 第一个表达,“阻塞IO模型是异步IO” 的说法是错误的,在UNP一书中有介绍,那么“阻塞IO模型是同步IO模型”正确么?...异步阻塞的区别主要在于是否需要等待获取对方状态后再返回。...看起来跟阻塞IO操作的概念没什么不同,其实不然。异步IO操作是:只要把request加入到队列中就返回。和阻塞IO操作不同的是,异步操作连描述符是否准备好也不需要去检查。...从上面的介绍可以得出: 如果一个IO操作是异步操作,那他一定是非阻塞的。但是如果阻塞操作却未必是异步IO操作。

    1.9K230

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

    有的人还会把阻塞/阻塞与同步/异步混合起来理解,认为阻塞=同步、阻塞=异步。 那么到底是不是这样呢?这篇文章,我们就从本质上跟大家分享一下这几个概念,到底应该怎么样去准确理解他们。...0 阻塞/阻塞 首先我们要明确的第一个概念是:阻塞/阻塞是一种现象,这是一个相对概念。 例如我们去医院看病。当你挂号之后,发现前面还有人在排队等待。那么前面的人,对于你而言,都是阻塞任务。...因此,我们学习的时候,重点不应该放在阻塞/阻塞的概念上,而是应该去关注任务执行顺序和任务优先级的约定。阻塞/阻塞只是在描述一个现象,一个结果。...例如当你在学习操作系统时,进程之间通信方式上,有的书或者文章,会给你灌输这样一个概念:blocking send:阻塞式发送,表示发送方进程一直被阻塞,直到消息被接受。...因此为了解决这个问题,我们在页面首页设计了一个进度条功能展示资源的加载进度,并以串行的方式加载图片。

    9510

    同步与异步阻塞阻塞

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

    1.2K20

    同步与异步 阻塞阻塞

    1.2对应技术的问题:           我所选择的排队方式就对应同步与异步。在队伍中等待就是同步,取号等待就是异步。          ...2.同步、异步阻塞阻塞的理解 2.1同步阻塞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.2K31

    通俗理解-异步阻塞

    为了更加形象的说明同步异步阻塞阻塞,我们以小明去买奶茶为例。 1.同步与异步 同步与异步的重点在消息通知的方式上,也就是调用结果通知的方式。...异步调用,要想获得结果,一般有两种方式: 1.主动轮询异步调用的结果 2.被调用方通过callback来通知调用方调用结果 生活实例 同步买奶茶:小明点单交钱,然后等着拿奶茶。...阻塞阻塞的理解 阻塞阻塞调用在发出去后,在消息返回之前,当前进/线程会被挂起,直到有消息返回,当前进/线程才会被激活。 阻塞阻塞调用在发出去后,不会阻塞当前进/线程,而会立即返回。...阻塞买奶茶:小明点单交钱,等着拿奶茶,等的过程中,时不时刷刷微博、朋友圈... 3.总结 同步与异步,重点在于消息通知的方式阻塞阻塞,重点在于等消息时候的行为。...所以,就有了下面4种组合方式: 同步阻塞:小明在柜台干等着拿奶茶; 同步阻塞:小明在柜台边刷微博边等着拿奶茶; 异步阻塞:小明拿着小票啥都不干,一直等着店员通知他拿奶茶; 异步阻塞:小明拿着小票,刷着微博

    12220
    领券