同步異步鳍征,阻塞與非阻塞

導(dǎo)言

最近在研究Mosn的IO模型的時(shí)候涉及到了netpoll這種經(jīng)典的golang模型掌猛,最終暴露粗goroutine-per-connection的開發(fā)模式供開發(fā)者使用熔脂,而goroutine-per-connection又是基于I/O多路復(fù)用和goroutine構(gòu)建的高性能原生網(wǎng)絡(luò)模型绰疤。在研究I/O多路復(fù)用時(shí)铜犬,《UNIX網(wǎng)絡(luò)編程》中,歸納總結(jié)了五種I/O模型轻庆,包括同步異步I/O:

  • 阻塞 I/O (Blocking I/O)
  • 非阻塞 I/O (Nonblocking I/O)
  • I/O 多路復(fù)用 (I/O multiplexing)
  • 信號驅(qū)動(dòng) I/O (Signal driven I/O)
  • 異步 I/O (Asynchronous I/O)
    因此癣猾,在研究I/O多路復(fù)用之前,先去明確下之前一直模糊的同步異步阻塞與非阻塞概念余爆。

0. 消息通知

當(dāng)一個(gè)同步調(diào)用發(fā)出后纷宇,調(diào)用者要一直等待返回消息(結(jié)果)通知后,才進(jìn)行后續(xù)邏輯的處理龙屉。當(dāng)一個(gè)異步調(diào)用發(fā)出后呐粘,調(diào)用者無法立刻得到返回信息,需要被調(diào)用者在完成后转捕,通過狀態(tài)、通知或回調(diào)來通知調(diào)用者唆垃。

1. 同步異步

1.1 判斷標(biāo)準(zhǔn)

  • 所謂同步就是一個(gè)任務(wù)的完成需要依賴另外一個(gè)任務(wù)時(shí)五芝,只有等待被依賴的任務(wù)完成后,依賴的任務(wù)才能算完成辕万,這是一種可靠的任務(wù)序列枢步。
  • 所謂異步是不需要等待被依賴的任務(wù)完成,只是通知被依賴的任務(wù)要完成什么工作渐尿,依賴的任務(wù)也立即執(zhí)行醉途,只要自己完成了整個(gè)任務(wù)就算完成了。

同步異步關(guān)注的是消息通信機(jī)制砖茸,同步的消息通信是調(diào)用者主動(dòng)等待調(diào)用結(jié)果的返回隘擎,異步是指調(diào)用者不等待被調(diào)用者的處理結(jié)果,等到被調(diào)用者有了結(jié)果之后再通過狀態(tài)凉夯,通知或者回調(diào)來啟動(dòng)調(diào)用者獲取結(jié)果的后續(xù)邏輯操作货葬。

2. 阻塞與非阻塞

2.1 判斷標(biāo)準(zhǔn)

阻塞調(diào)用是指調(diào)用結(jié)果返回之前采幌,發(fā)起調(diào)用的進(jìn)程會(huì)被掛起。非阻塞調(diào)用是指震桶,即使調(diào)用結(jié)果沒有返回休傍,調(diào)用進(jìn)程也可以處理其他消息。

阻塞與非阻塞關(guān)注的是蹲姐,程序在等待調(diào)用結(jié)果時(shí)的狀態(tài)(是否被掛起)

2.2 同步與阻塞的區(qū)別

  • 同步調(diào)用時(shí)磨取,調(diào)用進(jìn)程可能還是可以激活的,也可以處理其他消息柴墩,只不過根據(jù)定義忙厌,這個(gè)任務(wù)還沒做完,他要繼續(xù)主動(dòng)去確認(rèn)一些狀態(tài)來判斷這次調(diào)用任務(wù)是否完成拐邪,因此如果調(diào)用進(jìn)程同時(shí)去做了一些事情(調(diào)用另外一個(gè)函數(shù)(進(jìn)程))慰毅,要么他就需要在這兩者的邏輯處理中互相切換。

因此扎阶,

  • 如果這個(gè)線程在等待當(dāng)前函數(shù)返回時(shí)汹胃,仍在執(zhí)行其他消息處理,那這種情況就叫做同步非阻塞东臀;
  • 如果這個(gè)線程在等待當(dāng)前函數(shù)返回時(shí)着饥,沒有執(zhí)行其他消息處理,而是處于掛起等待狀態(tài)惰赋,那這種情況就叫做同步阻塞
  • 對于阻塞調(diào)用來說宰掉,調(diào)用進(jìn)程會(huì)被掛起等待被調(diào)用進(jìn)程(函數(shù))返回

2.3 阻塞與非阻塞性能對比

非阻塞(當(dāng)其不能立刻得到結(jié)果之前,被調(diào)用函數(shù)(進(jìn)程)不會(huì)阻塞當(dāng)前進(jìn)程)赁濒,因此非阻塞可以提高CPU的使用效率轨奄,但是也增加了時(shí)間成本:線程切換時(shí)間增加,因此做設(shè)計(jì)的時(shí)候需要做balance拒炎。

3. 同步/異步 & 阻塞/非阻塞

通過Lucifer下載軟件來舉例調(diào)用方式挪拟,如下

3.1 同步阻塞

進(jìn)程A同步阻塞式調(diào)用進(jìn)程B,A被掛起击你,等待B的返回結(jié)果繼續(xù)進(jìn)行后續(xù)邏輯玉组。

Lucifer啟動(dòng)下載后,盯著下載進(jìn)度條不做其他任何事(掛起不做其他事情丁侄,阻塞)直到下載完成(等待結(jié)果惯雳,同步)。

3.2 同步非阻塞

進(jìn)程A調(diào)用進(jìn)程B鸿摇,A此時(shí)可以接收處理其他消息石景,但是關(guān)于調(diào)用B的后續(xù)邏輯,需要等待B的返回結(jié)果。

Lucifer啟動(dòng)下載后鸵钝,打開steam玩Ark了(可以做其他事情)時(shí)不時(shí)回來切屏出來看下下載進(jìn)度(調(diào)用者等待調(diào)用結(jié)果糙臼,同步)

3.3 異步阻塞

進(jìn)程A調(diào)用進(jìn)程B,B完成后回去通知A(體現(xiàn)異步)恩商,但是A被掛起变逃,等待B的處理結(jié)果直到B有返回。

Lucifer啟動(dòng)下載后怠堪,盯著進(jìn)度條不做其他任何事(掛起不做其他任何事揽乱,阻塞),當(dāng)下載完成之后下載軟件會(huì)發(fā)出“端诳螅”的一聲并彈窗告知Lucifer已下載完成(被調(diào)用方完成任務(wù)后主動(dòng)通知)凰棉。

3.4 異步非阻塞

效率更高,A調(diào)用B陌粹, A調(diào)用完成后繼續(xù)處理后續(xù)邏輯撒犀,當(dāng)B處理完成任務(wù)后會(huì)將處理結(jié)果通過通知或回調(diào)的方式告知A。

Lucifer啟動(dòng)下載后掏秩,打開steam去玩Ark了(調(diào)用發(fā)起者發(fā)起調(diào)用后可以去做其他事)或舞,當(dāng)下載完成之后下載軟件會(huì)發(fā)出“叮”的一聲并彈窗高速Lucifer下載已完成(被調(diào)用方完成任務(wù)后主動(dòng)通知)蒙幻。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末映凳,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子邮破,更是在濱河造成了極大的恐慌诈豌,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件抒和,死亡現(xiàn)場離奇詭異矫渔,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)摧莽,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進(jìn)店門蚌斩,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人范嘱,你說我怎么就攤上這事≡蔽海” “怎么了丑蛤?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長撕阎。 經(jīng)常有香客問我受裹,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任棉饶,我火速辦了婚禮厦章,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘照藻。我一直安慰自己袜啃,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布幸缕。 她就那樣靜靜地躺著群发,像睡著了一般。 火紅的嫁衣襯著肌膚如雪发乔。 梳的紋絲不亂的頭發(fā)上熟妓,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天,我揣著相機(jī)與錄音栏尚,去河邊找鬼起愈。 笑死,一個(gè)胖子當(dāng)著我的面吹牛译仗,可吹牛的內(nèi)容都是我干的抬虽。 我是一名探鬼主播,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼古劲,長吁一口氣:“原來是場噩夢啊……” “哼斥赋!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起产艾,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤疤剑,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后闷堡,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體隘膘,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年杠览,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了弯菊。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,722評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡踱阿,死狀恐怖管钳,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情软舌,我是刑警寧澤才漆,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站佛点,受9級特大地震影響醇滥,放射性物質(zhì)發(fā)生泄漏黎比。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一鸳玩、第九天 我趴在偏房一處隱蔽的房頂上張望阅虫。 院中可真熱鬧,春花似錦不跟、人聲如沸颓帝。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽躲履。三九已至,卻和暖如春聊闯,著一層夾襖步出監(jiān)牢的瞬間工猜,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工菱蔬, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留篷帅,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓拴泌,卻偏偏與公主長得像魏身,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子蚪腐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評論 2 353

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