链接:https://www.zhihu.com/question/19732473/answer/141098848
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
一、对象
相信大家经常看到同步系统、异步系统及异步编程之类的文章,这些文章都是从系统层面来解释概念,这在一定程度上会让初学者费解。因此,我个人觉得可以降低维度,就是不管是同步、异步、阻塞及非阻塞,这些概念都是针对某一个具体的对象而言。在程序中,这个对象就是调用者,明确对象后,在来看看同步和异步的概念。
二、同步和异步
同步和异步概念以 “调用者的行为方式” 做区分。
当程序产生一个调用后,如果调用者主动等待该调用的结果,则称之为同步。
当程序产生一个调用后,如果调用者不以主动的方式等待结果,而是被调用者完成任务后,通过某种形式(消息等...)通知调用者,则称之为异步。
三、阻塞和非阻塞
那么,当调用产生后,不管调用者以何种方式(同步和异步)等待这个结果,在被调用者处理任务的那一段时间中,调用者处于何种状态就决定了阻塞和非阻塞。
也就是说,阻塞和非阻塞概念是以被调用者处理任务的时间内“调用者的状态”做区分。
同步方式:
(1)阻塞:调用者什么都不干,就一直在等待,就是停在程序的某条执行语句上。
(2)非阻塞:调用者去干别的活,但因为以主动等待结果的方式,所以得时不时的询问任务完成了没有。
异步方式:
(1)阻塞:调用者什么都不干,直至收到被调用者的通知。
(2)非阻塞:调用者去干别的活,当被调用者完成任务后,通知调用者,调用者就可以处理被调用者的返回结果了。(回调就是用来处理此时返回的结果)
这就很容易组合出同步阻塞、同步非阻塞、异步阻塞及异步非阻塞这四种类型的程序形式了。