• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 200, comments - 8, trackbacks - 0, articles - 0

            關(guān)于多進(jìn)程和多線程,教科書上最經(jīng)典的一句話是“進(jìn)程是資源分配的最小單位,線程是CPU調(diào)度的最小單位”。這句話應(yīng)付考試基本上夠了,但如果在工作中遇到類似的選擇問題,那就沒有那么簡單了,選的不好,會讓你深受其害。
            經(jīng)常在網(wǎng)絡(luò)上看到有XDJM問“多進(jìn)程好還是多線程好?”、"Linux下用多進(jìn)程還是多線程?"等等期望一勞永逸的問題,只能說:沒有最好,只有更好,根據(jù)實際情況來判斷,哪個更加合適就是哪個好。
            我們按照多個不同的維度,來看看多進(jìn)程和多線程的對比(注:因為是感性的比較,因此都是相對的,不是說一個好得不得了,另一個差的無法忍受)

            維度

            多進(jìn)程

            多線程

            總結(jié)

            數(shù)據(jù)共享、同步

            數(shù)據(jù)是分開的:共享復(fù)雜,需要用IPC;同步簡單

            多線程共享進(jìn)程數(shù)據(jù):共享簡單;同步復(fù)雜

            各有優(yōu)勢

            內(nèi)存、CPU

            占用內(nèi)存多,切換復(fù)雜,CPU利用率低

            占用內(nèi)存少,切換簡單,CPU利用率高

            線程占優(yōu)

            創(chuàng)建銷毀、切換

            創(chuàng)建銷毀、切換復(fù)雜,速度慢 

            創(chuàng)建銷毀、切換簡單,速度快 

            線程占優(yōu) 

            編程調(diào)試

            編程簡單,調(diào)試簡單

            編程復(fù)雜,調(diào)試復(fù)雜

            進(jìn)程占優(yōu) 

            可靠性

            進(jìn)程間不會相互影響 

            一個線程掛掉將導(dǎo)致整個進(jìn)程掛掉

            進(jìn)程占優(yōu)

            分布式 

            適應(yīng)于多核、多機分布 ;如果一臺機器不夠,擴展到多臺機器比較簡單

            適應(yīng)于多核分布

            進(jìn)程占優(yōu)



            1)需要頻繁創(chuàng)建銷毀的優(yōu)先用線程。
               實例:web服務(wù)器。來一個建立一個線程,斷了就銷毀線程。要是用進(jìn)程,創(chuàng)建和銷毀的代價是很難承受的。
            2)需要進(jìn)行大量計算的優(yōu)先使用線程。
               所謂大量計算,當(dāng)然就是要消耗很多cpu,切換頻繁了,這種情況先線程是最合適的。
               實例:圖像處理、算法處理
            3)強相關(guān)的處理用線程,若相關(guān)的處理用進(jìn)程。
               什么叫強相關(guān)、弱相關(guān)?理論上很難定義,給個簡單的例子就明白了。
               一般的server需要完成如下任務(wù):消息收發(fā)和消息處理。消息收發(fā)和消息處理就是弱相關(guān)的任務(wù),而消息處理里面可能又分為消息解碼、業(yè)務(wù)處理,這兩個任務(wù)相對來說相關(guān)性就要強多了。因此消息收發(fā)和消息處理可以分進(jìn)程設(shè)計,消息解碼和業(yè)務(wù)處理可以分線程設(shè)計。
            4)可能擴展到多機分布的用進(jìn)程,多核分布的用線程。
            5)都滿足需求的情況下,用你最熟悉、最拿手的方式。
               至于”數(shù)據(jù)共享、同步“、“編程、調(diào)試”、“可靠性”這幾個維度的所謂的“復(fù)雜、簡單”應(yīng)該怎么取舍,只能說:沒有明確的選擇方法。一般有一個選擇原則:如果多進(jìn)程和多線程都能夠滿足要求,那么選擇你最熟悉、最拿手的那個。
            需要提醒的是:雖然有這么多的選擇原則,但實際應(yīng)用中都是“進(jìn)程+線程”的結(jié)合方式,千萬不要真的陷入一種非此即彼的誤區(qū)。

            轉(zhuǎn)自:http://software.intel.com/zh-cn/blogs/2010/07/20/400004478/ 

            轉(zhuǎn)自:http://blog.chinaunix.net/uid-20556054-id-3061450.html
            亚洲国产精品人久久| 无码乱码观看精品久久| 99久久精品国产免看国产一区| 国产亚洲精品自在久久| 久久精品国产福利国产琪琪| 欧洲精品久久久av无码电影 | 久久人妻少妇嫩草AV蜜桃| 无码日韩人妻精品久久蜜桃| 久久久久99精品成人片三人毛片 | 久久美女网站免费| 亚洲AV成人无码久久精品老人 | 99精品国产在热久久| 九九久久精品国产| 久久综合狠狠综合久久激情 | 色老头网站久久网| 性做久久久久久久久老女人| 久久亚洲私人国产精品| 亚洲国产精品成人久久蜜臀 | 99久久精品国内| 亚洲AV无码一区东京热久久| 国产日韩久久免费影院| 国内精品久久久久久久亚洲| 日韩av无码久久精品免费| 久久国产欧美日韩精品免费| 久久久久久综合一区中文字幕 | 色综合久久中文色婷婷| 久久久久成人精品无码中文字幕| 国产aⅴ激情无码久久| 久久久久人妻精品一区二区三区| 午夜精品久久影院蜜桃| 久久九九久精品国产| 国产精久久一区二区三区| 精品午夜久久福利大片| 久久精品亚洲欧美日韩久久| 国产A级毛片久久久精品毛片| 狠狠色丁香婷综合久久| 国产精品久久永久免费| 丁香狠狠色婷婷久久综合| 99久久久精品| 国产精品伦理久久久久久| 国产免费久久精品99久久|