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

简介: 同步,异步,阻塞和非阻塞的理解

首先来说下概念:
同步:调用方等待被调用方执行完成,才能继续执行,在被调用方执行期间,调用方会一直等待。
异步:通常是被调用方直接返回一个结果,告诉调用方,我们已经接收到任务了,然后再去慢慢的执行任务。调用方直接获取到了结果,就会继续执行后面的任务。
阻塞:调用方虽然可能已经知道被调用方已经获取到任务了,但是就是想要等待被调用方真正的执行完成。
非阻塞:调用方不关心,也不会等待被调用方完成任务,因为如果有需要,被调用方会来通知调用方。

以上是我对同步与异步,阻塞与非阻塞的个人理解,其实同步和异步,主要是看被调用者的实现方式,而阻塞和非阻塞是由调用者所决定的,下面我们通过一个简单的生活例子来加强我们的理解:
情景一:10个人去面馆吃面,面馆的规矩是排队买面,即一个人付完钱,并取得面后,第二个人才能付钱拿面,这种方式就是同步的方式,效率非常低。
情景二:此时店家想了一个方法,一个人专门负责收钱,一个人专门负责下面,10个人只需要排队付钱,就能拿到小票,这样很快10个人就能完成点餐,而且下面的人也不需要一碗一碗的下了,这种方式就是异步了。
情景三:虽然我们拿到了小票,但是我们不知道自己的面什么时候好,所以我们还是在窗口前等待,这就是阻塞。
情景四:店员在每一碗好的时候,大喊一声小票号,吃面的人听到自己的号再去拿面,期间是不需要傻等,可以玩玩手机,这就是非阻塞。

在代码的角度去理解:
例如我们通过使用callable来开启一个多线程,此时是一次异步操作,如果我们不关心子线程的返回值是什么,那么我们就是非阻塞了,如果我们调用的Future的get方法,那么我们就被阻塞了。

目录
相关文章
|
7月前
|
API iOS开发
彻底搞懂同步与异步,阻塞/非阻塞
彻底搞懂同步与异步,阻塞/非阻塞
1709 0
阻塞式/非阻塞式与同步/异步的区别
阻塞式/非阻塞式与同步/异步的区别
95 0
理解阻塞、非阻塞与同步、异步的区别
理解阻塞、非阻塞与同步、异步的区别
理解阻塞、非阻塞与同步、异步的区别
阻塞/阻塞/同步/异步
咱就说有没有一种可能,同步、异步、阻塞、非阻塞,这几个关键词拆开看都感觉挺明白的。但是同步阻塞、同步非阻塞、异步阻塞、异步非阻塞,这几个关键词组装起来,看起来就有点那么晦涩了。这个在日常八股中经常出现字眼,其背后对应的到底是个什么样的逻辑?我们来一起揭开它那不那么神秘的面纱。/手动狗头。
120 0
阻塞/阻塞/同步/异步
网络基础 - 同步、异步、阻塞、非阻塞
网络基础 - 同步、异步、阻塞、非阻塞
205 0
|
缓存 Java
同步 异步 阻塞 非阻塞
在高性能的IO体系设计中,有几个名词概念常常会使我们感到迷惑不解。具体如下:  序号 问题 1 什么是同步? 2 什么是异步? 3 什么是阻塞? 4 什么是非阻塞? 5 什么是同步阻塞? 6 什么是同步非阻塞? 7 什么是异步阻塞? 8 什么是异步非阻塞? 散仙不才,在查了一部分资料后,愿试着以通俗易懂的方式
1885 1
同步、异步、阻塞、非阻塞
同步和异步关注的是消息通信机制 (synchronous communication/ asynchronous communication) 真正意义上的 异步IO 是说内核直接将数据拷贝至用户态的内存单元,再通知程序直接去读取数据。
1004 0