作者:嚴(yán)肅
鏈接:https://www.zhihu.com/question/19732473/answer/20851256
來源:知乎
著作權(quán)歸作者所有枝笨。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系作者獲得授權(quán)蚌卤,非商業(yè)轉(zhuǎn)載請(qǐng)注明出處簿盅。
“阻塞”與"非阻塞"與"同步"與“異步"不能簡單的從字面理解,提供一個(gè)從分布式系統(tǒng)角度的回答戚宦。1.同步與異步同步和異步關(guān)注的是消息通信機(jī)制 (synchronous communication/ asynchronous communication)所謂同步忌怎,就是在發(fā)出一個(gè)調(diào)用時(shí),在沒有得到結(jié)果之前执庐,該調(diào)用就不返回。但是一旦調(diào)用返回导梆,就得到返回值了轨淌。換句話說,就是由調(diào)用者主動(dòng)等待這個(gè)調(diào)用的結(jié)果看尼。而異步則是相反递鹉,調(diào)用在發(fā)出之后,這個(gè)調(diào)用就直接返回了藏斩,所以沒有返回結(jié)果躏结。換句話說,當(dāng)一個(gè)異步過程調(diào)用發(fā)出后狰域,調(diào)用者不會(huì)立刻得到結(jié)果媳拴。而是在調(diào)用發(fā)出后,被調(diào)用者通過狀態(tài)北专、通知來通知調(diào)用者禀挫,或通過回調(diào)函數(shù)處理這個(gè)調(diào)用。典型的異步編程模型比如Node.js舉個(gè)通俗的例子:你打電話問書店老板有沒有《分布式系統(tǒng)》這本書拓颓,如果是同步通信機(jī)制语婴,書店老板會(huì)說,你稍等,”我查一下"砰左,然后開始查啊查匿醒,等查好了(可能是5秒,也可能是一天)告訴你結(jié)果(返回結(jié)果)缠导。而異步通信機(jī)制廉羔,書店老板直接告訴你我查一下啊,查好了打電話給你僻造,然后直接掛電話了(不返回結(jié)果)憋他。然后查好了,他會(huì)主動(dòng)打電話給你髓削。在這里老板通過“回電”這種方式來回調(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)前線程好啰。還是上面的例子,你打電話問書店老板有沒有《分布式系統(tǒng)》這本書儿奶,你如果是阻塞式調(diào)用框往,你會(huì)一直把自己“掛起”,直到得到這本書有沒有的結(jié)果廓握,如果是非阻塞式調(diào)用搅窿,你不管老板有沒有告訴你嘁酿,你自己先一邊去玩了隙券, 當(dāng)然你也要偶爾過幾分鐘check一下老板有沒有返回結(jié)果。在這里阻塞與非阻塞與是否同步異步無關(guān)闹司。跟老板通過什么方式回答你結(jié)果無關(guān)娱仔。如果是關(guān)心blocking IO/ asynchronous IO, 參考 Unix Network Programming View Book作者:嚴(yán)肅
鏈接:https://www.zhihu.com/question/19732473/answer/20851256
來源:知乎
著作權(quán)歸作者所有。商業(yè)轉(zhuǎn)載請(qǐng)聯(lián)系作者獲得授權(quán)游桩,非商業(yè)轉(zhuǎn)載請(qǐng)注明出處牲迫。
“阻塞”與"非阻塞"與"同步"與“異步"不能簡單的從字面理解,提供一個(gè)從分布式系統(tǒng)角度的回答借卧。
1.同步與異步
同步和異步關(guān)注的是消息通信機(jī)制 (synchronous communication/ asynchronous communication)
所謂同步盹憎,就是在發(fā)出一個(gè)調(diào)用時(shí),在沒有得到結(jié)果之前铐刘,該調(diào)用就不返回陪每。但是一旦調(diào)用返回,就得到返回值了。
換句話說檩禾,就是由調(diào)用者主動(dòng)等待這個(gè)調(diào)用的結(jié)果挂签。
而異步則是相反,調(diào)用在發(fā)出之后****盼产,這個(gè)調(diào)用就直接返回了饵婆,所以沒有返回結(jié)果。換句話說戏售,當(dāng)一個(gè)異步過程調(diào)用發(fā)出后侨核,調(diào)用者不會(huì)立刻得到結(jié)果。而是在調(diào)用發(fā)出后灌灾,被調(diào)用者通過狀態(tài)芹关、通知來通知調(diào)用者,或通過回調(diào)函數(shù)處理這個(gè)調(diào)用紧卒。
典型的異步編程模型比如Node.js
舉個(gè)通俗的例子:
你打電話問書店老板有沒有《分布式系統(tǒng)》這本書侥衬,如果是同步通信機(jī)制,書店老板會(huì)說跑芳,你稍等轴总,”我查一下",然后開始查啊查博个,等查好了(可能是5秒怀樟,也可能是一天)告訴你結(jié)果(返回結(jié)果)。
而異步通信機(jī)制盆佣,書店老板直接告訴你我查一下啊往堡,查好了打電話給你,然后直接掛電話了(不返回結(jié)果)共耍。然后查好了虑灰,他會(huì)主動(dòng)打電話給你。在這里老板通過“回電”這種方式來回調(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)前線程遗淳。
還是上面的例子拍柒,
你打電話問書店老板有沒有《分布式系統(tǒng)》這本書,你如果是阻塞式調(diào)用屈暗,你會(huì)一直把自己“掛起”拆讯,直到得到這本書有沒有的結(jié)果剧包,如果是非阻塞式調(diào)用,你不管老板有沒有告訴你往果,你自己先一邊去玩了疆液, 當(dāng)然你也要偶爾過幾分鐘check一下老板有沒有返回結(jié)果。
在這里阻塞與非阻塞與是否同步異步無關(guān)陕贮。跟老板通過什么方式回答你結(jié)果無關(guān)堕油。
如果是關(guān)心blocking IO/ asynchronous IO, 參考 Unix Network Programming View Book