多進(jìn)程和多線程

關(guān)于多進(jìn)程和多線程正林,教科書上最經(jīng)典的一句話是“進(jìn)程是資源分配的最小單位泡一,線程是CPU調(diào)度的最小單位”,這句話應(yīng)付考試基本上夠了觅廓,但如果在工作中遇到類似的選擇問題,那就沒有這么簡(jiǎn)單了,選的不好塑娇,會(huì)讓你深受其害哨啃。

我們按照多個(gè)不同的維度,來(lái)看看多線程和多進(jìn)程的對(duì)比(注:因?yàn)槭歉行缘谋容^祝峻,因此都是相對(duì)的砸琅,不是說一個(gè)好得不得了症脂,另外一個(gè)差的無(wú)法忍受)。


對(duì)比圖

1)需要頻繁創(chuàng)建銷毀的優(yōu)先用線程

原因請(qǐng)看上面的對(duì)比悯辙。

這種原則最常見的應(yīng)用就是Web服務(wù)器了针贬,來(lái)一個(gè)連接建立一個(gè)線程谆棱,斷了就銷毀線程蔫劣,要是用進(jìn)程,創(chuàng)建和銷毀的代價(jià)是很難承受的

2)需要進(jìn)行大量計(jì)算的優(yōu)先使用線程

所謂大量計(jì)算绸罗,當(dāng)然就是要耗費(fèi)很多CPU外驱,切換頻繁了磅崭,這種情況下線程是最合適的砸喻。

這種原則最常見的是圖像處理、算法處理。

3)強(qiáng)相關(guān)的處理用線程,弱相關(guān)的處理用進(jìn)程

什么叫強(qiáng)相關(guān)婚肆、弱相關(guān)讨越?理論上很難定義人弓,給個(gè)簡(jiǎn)單的例子就明白了。

一般的Server需要完成如下任務(wù):消息收發(fā)县钥、消息處理痒留∝倚В“消息收發(fā)”和“消息處理”就是弱相關(guān)的任務(wù)碗殷,而“消息處理”里面可能又分為“消息解碼”锌妻、“業(yè)務(wù)處理”,這兩個(gè)任務(wù)相對(duì)來(lái)說相關(guān)性就要強(qiáng)多了吭历。因此“消息收發(fā)”和“消息處理”可以分進(jìn)程設(shè)計(jì),“消息解碼”、“業(yè)務(wù)處理”可以分線程設(shè)計(jì)。

當(dāng)然這種劃分方式不是一成不變的,也可以根據(jù)實(shí)際情況進(jìn)行調(diào)整。

4)可能要擴(kuò)展到多機(jī)分布的用進(jìn)程,多核分布的用線程

原因請(qǐng)看上面對(duì)比。

5)都滿足需求的情況下,用你最熟悉削葱、最拿手的方式

至于“數(shù)據(jù)共享、同步”、“編程胁塞、調(diào)試”蒙谓、“可靠性”這幾個(gè)維度的所謂的“復(fù)雜、簡(jiǎn)單”應(yīng)該怎么取舍,我只能說:沒有明確的選擇方法蜡坊。但我可以告訴你一個(gè)選擇原則:如果多進(jìn)程和多線程都能夠滿足要求鹦牛,那么選擇你最熟悉礼殊、最拿手的那個(gè)。

需要提醒的是:雖然我給了這么多的選擇原則竭业,但實(shí)際應(yīng)用中基本上都是“進(jìn)程+線程”的結(jié)合方式兼蜈,千萬(wàn)不要真的陷入一種非此即彼的誤區(qū)。

消耗資源:

從內(nèi)核的觀點(diǎn)看为狸,進(jìn)程的目的就是擔(dān)當(dāng)分配系統(tǒng)資源(CPU時(shí)間辐棒、內(nèi)存等)的基本單位漾根。線程是進(jìn)程的一個(gè)執(zhí)行流,是CPU調(diào)度和分派的基本單位秘蛇,它是比進(jìn)程更小的能獨(dú)立運(yùn)行的基本單位赁还。

線程,它們彼此之間使用相同的地址空間,共享大部分?jǐn)?shù)據(jù)源织,啟動(dòng)一個(gè)線程所花費(fèi)的空間遠(yuǎn)遠(yuǎn)小于啟動(dòng)一個(gè)進(jìn)程所花費(fèi)的空間,而且,線程間彼此切換所需的時(shí)間也遠(yuǎn)遠(yuǎn)小于進(jìn)程間切換所需要的時(shí)間医窿。據(jù)統(tǒng)計(jì)姥卢,總的說來(lái),一個(gè)進(jìn)程的開銷大約是一個(gè)線程開銷的30倍左右渣聚,當(dāng)然独榴,在具體的系統(tǒng)上,這個(gè)數(shù)據(jù)可能會(huì)有較大的區(qū)別奕枝。

通訊方式:

進(jìn)程之間傳遞數(shù)據(jù)只能是通過通訊的方式棺榔,即費(fèi)時(shí)又不方便。線程時(shí)間數(shù)據(jù)大部分共享(線程函數(shù)內(nèi)部不共享)隘道,快捷方便症歇。但是數(shù)據(jù)同步需要鎖對(duì)于static變量尤其注意

線程自身優(yōu)勢(shì):

提高應(yīng)用程序響應(yīng);使多CPU系統(tǒng)更加有效谭梗。操作系統(tǒng)會(huì)保證當(dāng)線程數(shù)不大于CPU數(shù)目時(shí)忘晤,不同的線程運(yùn)行于不同的CPU上;

改善程序結(jié)構(gòu)激捏。一個(gè)既長(zhǎng)又復(fù)雜的進(jìn)程可以考慮分為多個(gè)線程设塔,成為幾個(gè)獨(dú)立或半獨(dú)立的運(yùn)行部分,這樣的程序會(huì)利于理解和修改缩幸。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末壹置,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子表谊,更是在濱河造成了極大的恐慌,老刑警劉巖盖喷,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件爆办,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡课梳,警方通過查閱死者的電腦和手機(jī)距辆,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門余佃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人跨算,你說我怎么就攤上這事爆土。” “怎么了诸蚕?”我有些...
    開封第一講書人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵步势,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我背犯,道長(zhǎng)坏瘩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任漠魏,我火速辦了婚禮倔矾,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘柱锹。我一直安慰自己哪自,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開白布禁熏。 她就那樣靜靜地躺著壤巷,像睡著了一般。 火紅的嫁衣襯著肌膚如雪匹层。 梳的紋絲不亂的頭發(fā)上隙笆,一...
    開封第一講書人閱讀 49,007評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音升筏,去河邊找鬼撑柔。 笑死,一個(gè)胖子當(dāng)著我的面吹牛您访,可吹牛的內(nèi)容都是我干的铅忿。 我是一名探鬼主播,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼灵汪,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼檀训!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起享言,我...
    開封第一講書人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤峻凫,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后览露,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體荧琼,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了命锄。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片堰乔。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖脐恩,靈堂內(nèi)的尸體忽然破棺而出镐侯,到底是詐尸還是另有隱情,我是刑警寧澤驶冒,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布苟翻,位于F島的核電站,受9級(jí)特大地震影響只怎,放射性物質(zhì)發(fā)生泄漏袜瞬。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一身堡、第九天 我趴在偏房一處隱蔽的房頂上張望邓尤。 院中可真熱鬧,春花似錦贴谎、人聲如沸汞扎。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)澈魄。三九已至,卻和暖如春仲翎,著一層夾襖步出監(jiān)牢的瞬間痹扇,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工溯香, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留鲫构,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓玫坛,卻偏偏與公主長(zhǎng)得像结笨,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子湿镀,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345

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