日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

浅谈多进程多线程的选择(转)

發布時間:2025/3/21 编程问答 21 豆豆
生活随笔 收集整理的這篇文章主要介紹了 浅谈多进程多线程的选择(转) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

關于多進程和多線程,教科書上最經典的一句話是“進程是資源分配的最小單位,線程是CPU調度的最小單位”,這句話應付考試基本上夠了,但如果在工作中遇到類似的選擇問題,那就沒有這么簡單了,選的不好,會讓你深受其害。

?

經常在網絡上看到有的XDJM問“多進程好還是多線程好?”、“Linux下用多進程還是多線程?”等等期望一勞永逸的問題,我只能說:沒有最好,只有更好。根據實際情況來判斷,哪個更加合適就是哪個好。

?

我們按照多個不同的維度,來看看多線程和多進程的對比(注:因為是感性的比較,因此都是相對的,不是說一個好得不得了,另外一個差的無法忍受)。

?

對比維度

多進程

多線程

總結

數據共享、同步

數據共享復雜,需要用IPC;數據是分開的,同步簡單

因為共享進程數據,數據共享簡單,但也是因為這個原因導致同步復雜

各有優勢

內存、CPU

占用內存多,切換復雜,CPU利用率低

占用內存少,切換簡單,CPU利用率高

線程占優

創建銷毀、切換

創建銷毀、切換復雜,速度慢

創建銷毀、切換簡單,速度很快

線程占優

編程、調試

編程簡單,調試簡單

編程復雜,調試復雜

進程占優

可靠性

進程間不會互相影響

一個線程掛掉將導致整個進程掛掉

進程占優

分布式

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

適應于多核分布式

進程占優

?

看起來比較簡單,優勢對比上是“線程 3.5 v 2.5 進程”,我們只管選線程就是了?

?

呵呵,有這么簡單我就不用在這里浪費口舌了,還是那句話,沒有絕對的好與壞,只有哪個更加合適的問題。我們來看實際應用中究竟如何判斷更加合適。

1)需要頻繁創建銷毀的優先用線程

原因請看上面的對比。

這種原則最常見的應用就是Web服務器了,來一個連接建立一個線程,斷了就銷毀線程,要是用進程,創建和銷毀的代價是很難承受的

2)需要進行大量計算的優先使用線程

所謂大量計算,當然就是要耗費很多CPU,切換頻繁了,這種情況下線程是最合適的。

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

3)強相關的處理用線程,弱相關的處理用進程

什么叫強相關、弱相關?理論上很難定義,給個簡單的例子就明白了。

一般的Server需 要完成如下任務:消息收發、消息處理。“消息收發”和“消息處理”就是弱相關的任務,而“消息處理”里面可能又分為“消息解碼”、“業務處理”,這兩個任 務相對來說相關性就要強多了。因此“消息收發”和“消息處理”可以分進程設計,“消息解碼”、“業務處理”可以分線程設計。

當然這種劃分方式不是一成不變的,也可以根據實際情況進行調整。

4)可能要擴展到多機分布的用進程,多核分布的用線程

原因請看上面對比。

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

至于“數據共享、同步”、“編程、調試”、“可靠性”這幾個維度的所謂的“復雜、簡單”應該怎么取舍,我只能說:沒有明確的選擇方法。但我可以告訴你一個選擇原則:如果多進程和多線程都能夠滿足要求,那么選擇你最熟悉、最拿手的那個。

?

需要提醒的是:雖然我給了這么多的選擇原則,但實際應用中基本上都是“進程+線程”的結合方式,千萬不要真的陷入一種非此即彼的誤區。

?

?

?

1、多進程與多線程的簡單比較

  • 多進程
  • 優點:內存隔離,單個進程的異常不會導致整個應用的崩潰。方便測試,編程簡單。

    ? ??缺點:進程間調用,通訊和切換均比多線程大,耗資源。

    使用場所:目標子動能交互少,如果資源和性能許可,可以設計由多個子應用程序來組合完成目的。

  • 多線程?
  • 優點:提高系統的并行性,并且開銷小。數據共享方便(不需要進程間的通信)

    缺點:沒有內存隔離,單個現成的崩潰會導致整個應用程序的退出,發生采內存等bug時,定位及其不方便。編程復雜;調試困難;線程執行的隨機性可能導致邏輯混亂,甚至發生死鎖現象;

    使用場所:在存在大量IO,網絡等耗時操作,或者需要和用戶交互時,使用多線程有利于提高系統的并行性和用戶界面快速響應從而提高友好性。

    2、設計時應注意的事項

  • 盡量避免長駐內存的進程,例如那些很少用到的功能,或周期性很長(10分鐘以上),
  • 把它們的功能提取出來,做成一個小的應用程序。需要的時候再把它們拉起來(如通過crontab配置,或直接system)。

  • 把目標設計成子功能系統的組合可用提高重用的易用性和維護性。
  • 把目標根據功能劃分不同的子系統,子系統間遵循特定的協議(文本或XML),由通訊聯系起來,協作完成目標。

    典型的案例就是UNIX或LINUX的工具使用。如:$ cat veglist fruitlist | sort > clist,用cat打開文件,協議是字符流,通過管道(通訊手段)傳給sort進行排序,把排序的結果流重定向到文件中。這種自由組合協作風格應用思想和編程思路也是吸引眾多UNIX擁護者的原因之一吧。

    ???? 在軟件設計中,選擇多進程還是多線程還跟很多因素有關,例如對數據實時處理的性能要求、對健壯性和安全性要求、是否要求跨平臺(包括操作系統和數據庫)及是否需要分布部署。因此,在設計中應充分考慮各種因素以求做到最大利用系統資源。

    總結

    以上是生活随笔為你收集整理的浅谈多进程多线程的选择(转)的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。