同步與異步,阻塞與非阻塞通俗解釋

作者:嚴(yán)肅

鏈接:https://www.zhihu.com/question/19732473/answer/20851256

來(lái)源:知乎

著作權(quán)歸作者所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系作者獲得授權(quán),非商業(yè)轉(zhuǎn)載請(qǐng)注明出處。

“阻塞”與"非阻塞"與"同步"與“異步"不能簡(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)用返回,就得到返回值了。

換句話(huà)說(shuō),就是由*調(diào)用者*主動(dòng)等待這個(gè)*調(diào)用*的結(jié)果。

而異步則是相反,*調(diào)用*在發(fā)出之后,這個(gè)調(diào)用就直接返回了,所以沒(méi)有返回結(jié)果。換句話(huà)說(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è)通俗的例子:

你打電話(huà)問(wèn)書(shū)店老板有沒(méi)有《分布式系統(tǒng)》這本書(shū),如果是同步通信機(jī)制,書(shū)店老板會(huì)說(shuō),你稍等,”我查一下",然后開(kāi)始查啊查,等查好了(可能是5秒,也可能是一天)告訴你結(jié)果(返回結(jié)果)。

而異步通信機(jī)制,書(shū)店老板直接告訴你我查一下啊,查好了打電話(huà)給你,然后直接掛電話(huà)了(不返回結(jié)果)。然后查好了,他會(huì)主動(dòng)打電話(huà)給你。在這里老板通過(guò)“回電”這種方式來(lái)回調(diào)。

2. 阻塞與非阻塞

阻塞和非阻塞關(guān)注的是程序在等待調(diào)用結(jié)果(消息,返回值)時(shí)的狀態(tài).

阻塞調(diào)用是指調(diào)用結(jié)果返回之前,當(dāng)前線(xiàn)程會(huì)被掛起。調(diào)用線(xiàn)程只有在得到結(jié)果之后才會(huì)返回。

非阻塞調(diào)用指在不能立刻得到結(jié)果之前,該調(diào)用不會(huì)阻塞當(dāng)前線(xiàn)程。

還是上面的例子,

你打電話(huà)問(wèn)書(shū)店老板有沒(méi)有《分布式系統(tǒng)》這本書(shū),你如果是阻塞式調(diào)用,你會(huì)一直把自己“掛起”,直到得到這本書(shū)有沒(méi)有的結(jié)果,如果是非阻塞式調(diào)用,你不管老板有沒(méi)有告訴你,你自己先一邊去玩了, 當(dāng)然你也要偶爾過(guò)幾分鐘check一下老板有沒(méi)有返回結(jié)果。

在這里阻塞與非阻塞與是否同步異步無(wú)關(guān)。跟老板通過(guò)什么方式回答你結(jié)果無(wú)關(guān)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容