为了更加形象的说明同步异步、阻塞非阻塞,我们以小明去买奶茶为例。
1.同步与异步
同步与异步的重点在消息通知的方式上,也就是调用结果通知的方式。
同步与异步的理解
同步
:当一个同步调用发出去后,调用者要一直等待调用结果的通知后,才能进行后续的执行。
异步
:当一个异步调用发出去后,调用者不能立即得到调用结果的返回。
异步调用,要想获得结果,一般有两种方式: 1.主动轮询异步调用的结果 2.被调用方通过callback来通知调用方调用结果
生活实例
同步买奶茶
:小明点单交钱,然后等着拿奶茶。
异步买奶茶
:小明点单交钱,店员给小明一个小票,等小明奶茶做好了,再来取。
异步买奶茶,小明要想知道奶茶是否做好了,有两种方式: 1.小明主动去问店员,一会就去问一下:“奶茶做好了吗?”...直到奶茶做好。这叫轮训。 2.等奶茶做好了,店员喊一声:“小明,奶茶好了!”,然后小明去取奶茶。这叫回调。
2.阻塞与非阻塞
阻塞与非阻塞的重点在于进/线程等待消息时候的行为,也就是在等待消息的时候,当前进/线程是挂起状态,还是非挂起状态。
阻塞与非阻塞的理解
阻塞
:阻塞调用在发出去后,在消息返回之前,当前进/线程会被挂起,直到有消息返回,当前进/线程才会被激活。
非阻塞
:非阻塞调用在发出去后,不会阻塞当前进/线程,而会立即返回。
生活实例
阻塞买奶茶
:小明点单交钱,干等着拿奶茶,什么事都不做。
非阻塞买奶茶
:小明点单交钱,等着拿奶茶,等的过程中,时不时刷刷微博、朋友圈...
3.总结
同步与异步,重点在于
消息通知的方式
; 阻塞与非阻塞,重点在于等消息时候的行为
。
所以,就有了下面4种组合方式:
- 同步阻塞:小明在柜台干等着拿奶茶;
- 同步非阻塞:小明在柜台边刷微博边等着拿奶茶;
- 异步阻塞:小明拿着小票啥都不干,一直等着店员通知他拿奶茶;
- 异步非阻塞:小明拿着小票,刷着微博,等着店员通知他拿奶茶。
本文参考自nginx、swoole高并发原理初探