一、同步与异步
同步和异步关注的是消息通信机制
同步:在发出一个调用时,在没有得到结果之前,该调用就不返回。但是一旦调用返回,就得到返回值了。换句话说,就是由调用者主动等待这个调用的结果。
异步:与同步相反,调用在发出之后,这个调用就直接返回了,所以没有返回结果。换句话说,当一个异步过程调用发出后,调用者不会立刻得到结果,而是在调用发出后,等被调用者准备好数据后反过来通知调用者。(回调)
举个栗子:
你有点饿了,想去饭店吃饭,但是这时饭店的人有点多,如果是同步通信机制,你就一直在饭店等着,等呀等呀(等的时间不确定,可能一会就好了,也可能半天才好),一直等到你的饭做好为止(返回结果),然后你就开开心心的吃上饭啦。
而如果是异步通信机制,饭店老板会直接告诉你,“我们这会人有点多呀,一时半会也轮不到你,要不你先回去,等饭做好了我打电话给你呀”(不返回结果)。然后等饭好了,老板会主动打电话给你。在这里老板通过“回电话”这种方式来回调。
二、阻塞与非阻塞
阻塞和非阻塞关注的是程序在等待调用结果(消息,返回值)时的状态。
阻塞:指方法(函数)执行后,在结果返回之前,当前线程(进程)会被挂起。调用线程(进程)只有在得到结果之后才会返回。
非阻塞:指在不能立刻得到结果之前,该方法(函数)不会阻塞当前线程,可以立即返回,只是返回结果是失败,没有数据,一般需要 CPU 周期性轮询,以检查数据是否就绪。
举个栗子:
你又饿啦,你去炸鸡店买炸鸡,你问老板还有没有炸鸡,如果是阻塞式调用,你会一直把自己“挂起”,直到得到炸鸡有没有的结果
如果是非阻塞式调用,你不管老板有没有告诉你,你自己先一边去买饮料去了, 当然你也要偶尔隔一段时间来检查一下老板有没有告诉你结果。
注意:在这里阻塞和非阻塞与是否同步异步无关;跟通过什么方式返回结果无关。