阻塞,非阻塞,同步和異步

作者:嚴(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

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市肮之,隨后出現(xiàn)的幾起案子掉缺,更是在濱河造成了極大的恐慌,老刑警劉巖戈擒,帶你破解...
    沈念sama閱讀 221,888評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件眶明,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡筐高,警方通過查閱死者的電腦和手機(jī)搜囱,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,677評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門捞魁,熙熙樓的掌柜王于貴愁眉苦臉地迎上來钾菊,“玉大人,你說我怎么就攤上這事磺箕』粒” “怎么了扮宠?”我有些...
    開封第一講書人閱讀 168,386評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長狐榔。 經(jīng)常有香客問我坛增,道長,這世上最難降的妖魔是什么薄腻? 我笑而不...
    開封第一講書人閱讀 59,726評(píng)論 1 297
  • 正文 為了忘掉前任收捣,我火速辦了婚禮,結(jié)果婚禮上被廓,老公的妹妹穿的比我還像新娘坏晦。我一直安慰自己萝玷,他們只是感情好嫁乘,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,729評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著球碉,像睡著了一般蜓斧。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上睁冬,一...
    開封第一講書人閱讀 52,337評(píng)論 1 310
  • 那天挎春,我揣著相機(jī)與錄音看疙,去河邊找鬼。 笑死直奋,一個(gè)胖子當(dāng)著我的面吹牛能庆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播脚线,決...
    沈念sama閱讀 40,902評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼搁胆,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了邮绿?” 一聲冷哼從身側(cè)響起渠旁,我...
    開封第一講書人閱讀 39,807評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎船逮,沒想到半個(gè)月后顾腊,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,349評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡挖胃,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,439評(píng)論 3 340
  • 正文 我和宋清朗相戀三年杂靶,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片酱鸭。...
    茶點(diǎn)故事閱讀 40,567評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡伪煤,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出凛辣,到底是詐尸還是另有隱情抱既,我是刑警寧澤,帶...
    沈念sama閱讀 36,242評(píng)論 5 350
  • 正文 年R本政府宣布扁誓,位于F島的核電站防泵,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏蝗敢。R本人自食惡果不足惜捷泞,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,933評(píng)論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望寿谴。 院中可真熱鬧锁右,春花似錦、人聲如沸讶泰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,420評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽痪署。三九已至码泞,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間狼犯,已是汗流浹背余寥。 一陣腳步聲響...
    開封第一講書人閱讀 33,531評(píng)論 1 272
  • 我被黑心中介騙來泰國打工领铐, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人宋舷。 一個(gè)月前我還...
    沈念sama閱讀 48,995評(píng)論 3 377
  • 正文 我出身青樓绪撵,卻偏偏與公主長得像,于是被迫代替她去往敵國和親祝蝠。 傳聞我的和親對(duì)象是個(gè)殘疾皇子莲兢,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,585評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容