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

1.同步与异步

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

同步与异步的理解

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

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

生活实例

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

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

2.阻塞与非阻塞

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

阻塞与非阻塞的理解

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

生活实例

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

3.总结

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

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

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

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