通俗理解-异步非阻塞

为了更加形象的说明同步异步、阻塞非阻塞,我们以小明去买奶茶为例。

1.同步与异步

同步与异步的重点在消息通知的方式上,也就是调用结果通知的方式。

同步与异步的理解

同步:当一个同步调用发出去后,调用者要一直等待调用结果的通知后,才能进行后续的执行。
异步:当一个异步调用发出去后,调用者不能立即得到调用结果的返回。

异步调用,要想获得结果,一般有两种方式:
1.主动轮询异步调用的结果
2.被调用方通过callback来通知调用方调用结果

生活实例

同步买奶茶:小明点单交钱,然后等着拿奶茶。
异步买奶茶:小明点单交钱,店员给小明一个小票,等小明奶茶做好了,再来取。

异步买奶茶,小明要想知道奶茶是否做好了,有两种方式:
1.小明主动去问店员,一会就去问一下:“奶茶做好了吗?”...直到奶茶做好。这叫轮训。
2.等奶茶做好了,店员喊一声:“小明,奶茶好了!”,然后小明去取奶茶。这叫回调。

2.阻塞与非阻塞

阻塞与非阻塞的重点在于进/线程等待消息时候的行为,也就是在等待消息的时候,当前进/线程是挂起状态,还是非挂起状态。

阻塞与非阻塞的理解

阻塞:阻塞调用在发出去后,在消息返回之前,当前进/线程会被挂起,直到有消息返回,当前进/线程才会被激活。
非阻塞:非阻塞调用在发出去后,不会阻塞当前进/线程,而会立即返回。

生活实例

阻塞买奶茶:小明点单交钱,干等着拿奶茶,什么事都不做。
非阻塞买奶茶:小明点单交钱,等着拿奶茶,等的过程中,时不时刷刷微博、朋友圈...

3.总结

同步与异步,重点在于消息通知的方式
阻塞与非阻塞,重点在于等消息时候的行为

所以,就有了下面4种组合方式:

  • 同步阻塞:小明在柜台干等着拿奶茶;
  • 同步非阻塞:小明在柜台边刷微博边等着拿奶茶;
  • 异步阻塞:小明拿着小票啥都不干,一直等着店员通知他拿奶茶;
  • 异步非阻塞:小明拿着小票,刷着微博,等着店员通知他拿奶茶。

本文参考自nginx、swoole高并发原理初探

已有 8 条评论
  1. 小轲

    哈哈,我来了~ 嘻嘻

    小轲 July 3rd, 2018 at 05:12 pm回复
    1. LukaChen

      N年不写,已生锈。。。

      LukaChen July 20th, 2018 at 06:21 pm回复
  2. 子午

    看看评论。。。。

    子午 May 24th, 2018 at 04:24 pm回复
    1. LukaChen

      各位大佬不要带节奏。。。

      LukaChen May 25th, 2018 at 04:16 pm回复
  3. 小轲

    求更新啊博主~~~ 哈哈

    小轲 March 18th, 2018 at 01:12 pm回复
    1. LukaChen

      最近刚换工作,在熟悉新业务呢,哈哈~~~~

      LukaChen March 29th, 2018 at 11:37 pm回复
  4. True

    博客更新不勤快啊୧(๑•̀⌄•́๑)૭

    True March 8th, 2018 at 03:35 pm回复
    1. LukaChen

      (..•˘_˘•..)

      LukaChen March 8th, 2018 at 05:18 pm回复
发表新评论