“阻塞”與"非阻塞"與"同步"與“異步"不能簡(jiǎn)單的從字面理解,提供一個(gè)從分布式系統(tǒng)角度的回答腕柜。
1.同步與異步
同步和異步關(guān)注的是消息通信機(jī)制 (synchronous communication/ asynchronous communication)
所謂同步济似,就是在發(fā)出一個(gè)調(diào)用時(shí),在沒(méi)有得到結(jié)果之前盏缤,該調(diào)用就不返回砰蠢。但是一旦調(diào)用返回,就得到返回值了唉铜。
換句話說(shuō)台舱,就是由調(diào)用者主動(dòng)等待這個(gè)調(diào)用的結(jié)果。
而異步則是相反潭流,調(diào)用在發(fā)出之后竞惋,這個(gè)調(diào)用就直接返回了,所以沒(méi)有返回結(jié)果灰嫉。換句話說(shuō)拆宛,當(dāng)一個(gè)異步過(guò)程調(diào)用發(fā)出后,調(diào)用者不會(huì)立刻得到結(jié)果讼撒。而是在調(diào)用發(fā)出后浑厚,被調(diào)用者通過(guò)狀態(tài)、通知來(lái)通知調(diào)用者根盒,或通過(guò)回調(diào)函數(shù)處理這個(gè)調(diào)用钳幅。
典型的異步編程模型比如Node.js
舉個(gè)通俗的例子:
你打電話問(wèn)書店老板有沒(méi)有《分布式系統(tǒng)》這本書,如果是同步通信機(jī)制炎滞,書店老板會(huì)說(shuō)敢艰,你稍等,”我查一下"厂榛,然后開始查啊查盖矫,等查好了(可能是5秒,也可能是一天)告訴你結(jié)果(返回結(jié)果)击奶。
而異步通信機(jī)制辈双,書店老板直接告訴你我查一下啊,查好了打電話給你柜砾,然后直接掛電話了(不返回結(jié)果)湃望。然后查好了,他會(huì)主動(dòng)打電話給你痰驱。在這里老板通過(guò)“回電”這種方式來(lái)回調(diào)证芭。
2. 阻塞與非阻塞
阻塞和非阻塞關(guān)注的是程序在等待調(diào)用結(jié)果(消息,返回值)時(shí)的狀態(tài).
阻塞調(diào)用是指調(diào)用結(jié)果返回之前担映,當(dāng)前線程會(huì)被掛起废士。調(diào)用線程只有在得到結(jié)果之后才會(huì)返回。
非阻塞調(diào)用指在不能立刻得到結(jié)果之前蝇完,該調(diào)用不會(huì)阻塞當(dāng)前線程官硝。
還是上面的例子,
你打電話問(wèn)書店老板有沒(méi)有《分布式系統(tǒng)》這本書短蜕,你如果是阻塞式調(diào)用氢架,你會(huì)一直把自己“掛起”朋魔,直到得到這本書有沒(méi)有的結(jié)果,如果是非阻塞式調(diào)用孙援,你不管老板有沒(méi)有告訴你扇雕,你自己先一邊去玩了, 當(dāng)然你也要偶爾過(guò)幾分鐘check一下老板有沒(méi)有返回結(jié)果邻辉。
在這里阻塞與非阻塞與是否同步異步無(wú)關(guān)腮鞍。跟老板通過(guò)什么方式回答你結(jié)果無(wú)關(guān)。