色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

如何選好多線程和多進程

Q4MP_gh_c472c21 ? 來源:未知 ? 作者:胡薇 ? 2018-05-11 16:16 ? 次閱讀

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

進程與線程

進程是程序執行時的一個實例,即它是程序已經執行到課中程度的數據結構的匯集。從內核的觀點看,進程的目的就是擔當分配系統資源(CPU時間、內存等)的基本單位。

線程是進程的一個執行流,是CPU調度和分派的基本單位,它是比進程更小的能獨立運行的基本單位。一個進程由幾個線程組成(擁有很多相對獨立的執行流的用戶程序共享應用程序的大部分數據結構),線程與同屬一個進程的其他的線程共享進程所擁有的全部資源。

"進程——資源分配的最小單位,線程——程序執行的最小單位"

進程有獨立的地址空間,一個進程崩潰后,在保護模式下不會對其它進程產生影響,而線程只是一個進程中的不同執行路徑。線程有自己的堆棧和局部變量,但線程沒有單獨的地址空間,一個線程死掉就等于整個進程死掉,所以多進程的程序要比多線程的程序健壯,但在進程切換時,耗費資源較大,效率要差一些。但對于一些要求同時進行并且又要共享某些變量的并發操作,只能用線程,不能用進程。

總的來說就是:進程有獨立的地址空間,線程沒有單獨的地址空間(同一進程內的線程共享進程的地址空間)。

使用多線程的理由之一是和進程相比,它是一種非常"節儉"的多任務操作方式。我們知道,在Linux系統下,啟動一個新的進程必須分配給它獨立的地址空間,建立眾多的數據表來維護它的代碼段、堆棧段和數據段,這是一種"昂貴"的多任務工作方式。而運行于一個進程中的多個線程,它們彼此之間使用相同的地址空間,共享大部分數據,啟動一個線程所花費的空間遠遠小于啟動一個進程所花費的空間,而且,線程間彼此切換所需的時間也遠遠小于進程間切換所需要的時間。據統計,總的說來,一個進程的開銷大約是一個線程開銷的30倍左右,當然,在具體的系統上,這個數據可能會有較大的區別。

使用多線程的理由之二是線程間方便的通信機制。對不同進程來說,它們具有獨立的數據空間,要進行數據的傳遞只能通過通信的方式進行,這種方式不僅費時,而且很不方便。線程則不然,由于同一進程下的線程之間共享數據空間,所以一個線程的數據可以直接為其它線程所用,這不僅快捷,而且方便。當然,數據的共享也帶來其他一些問題,有的變量不能同時被兩個線程所修改,有的子程序中聲明為static的數據更有可能給多線程程序帶來災難性的打擊,這些正是編寫多線程程序時最需要注意的地方。

除了以上所說的優點外,不和進程比較,多線程程序作為一種多任務、并發的工作方式,當然有以下的優點:

·提高應用程序響應。這對圖形界面的程序尤其有意義,當一個操作耗時很長時,整個系統都會等待這個操作,此時程序不會響應鍵盤、鼠標、菜單的操作,而使用多線程技術,將耗時長的操作(time consuming)置于一個新的線程,可以避免這種尷尬的情況。

·使多CPU系統更加有效。操作系統會保證當線程數不大于CPU數目時,不同的線程運行于不同的CPU上。

·改善程序結構。一個既長又復雜的進程可以考慮分為多個線程,成為幾個獨立或半獨立的運行部分,這樣的程序會利于理解和修改。

我們按照多個不同的維度,做一個對比標看看多線程和多進程的具體區別:

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

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

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

原因請看上面的對比。

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

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

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

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

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

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

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

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

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

原因請看上面對比。

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

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

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

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 多線程
    +關注

    關注

    0

    文章

    278

    瀏覽量

    20018
  • 多進程
    +關注

    關注

    0

    文章

    14

    瀏覽量

    2628

原文標題:多線程還是多進程?選的不好你會深受其害

文章出處:【微信號:gh_c472c2199c88,微信公眾號:嵌入式微處理器】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    進程線程區別

    )。不管是多進程還是多線程,最終目標都是實現并行執行。 2、多線程的優勢前些年多進程多一些,近些年多線程開始用得多?,F代操作系統設計時考慮到
    發表于 11-30 14:06

    多線程多進程的區別

    6.你的數據庫一會又500個連接數,一會有10個,你分析一下情況7.udp和tcp的區別8.多線程多進程的區別9.有一臺web服務器,你選擇用多線程還是多進程,...
    發表于 07-19 07:21

    淺談多進程多線程的選擇

    魚還是熊掌:淺談多進程多線程的選擇關于多進程多線程,教科書上最經典的一句話是“進程是資源分配的最小單位,
    發表于 08-24 07:38

    python多線程多進程對比

    電視邊吃飯邊聊天。這就是我們的 多進程 才能做的事了。2. 單線程VS多線程VS多進程文字總是蒼白無力的,不如用代碼直接來測試一下。開始對比之前,首先定義四種類型的場景 - CPU計算
    發表于 03-15 16:42

    LINUX系統下多線程多進程性能分析

    采用多進程處理多個任務,會占用很多系統資源(主要是CPU 和內存的使用)。在LINUX 中,則對這種弊端進行了改進,在用戶態實現了多線程處理多任務。本文系統論述了多線程
    發表于 08-13 08:31 ?20次下載

    linux多線程編程技術

    (process)中只允許有一個線程,這樣多線程就意味著多進程?,F在,多線程技術已經被許多操作系統所支持,包括Windows/NT,當然,也包括Linux。 為什么有了
    發表于 10-24 16:01 ?5次下載

    什么是多線程編程?多線程編程基礎知識

    摘要:多線程編程是現代軟件技術中很重要的一個環節。要弄懂多線程,這就要牽涉到多進程。本文主要以多線程編程以及多線程編程相關知識而做出的一些結
    發表于 12-08 16:30 ?1.3w次閱讀

    多進程多線程的深度比較

    嵌入式Linux中文站,關于多進程多線程,教科書上最經典的一句話是“進程是資源分配的最小單位,線程是CPU調度的最小單位”。這句話應付考試基本上夠了,但如果在工作中遇
    發表于 04-02 14:42 ?479次閱讀

    多進程多線程的基本概念

    stack),自己的寄存器環境(register context),自己的線程本地存儲(thread-local storage)。一個進程可以有很多線程,每條線程并行執行不同的任務
    發表于 04-02 14:49 ?753次閱讀

    Python多進程學習

    Python 多進程 (Multiprocessing) 是一種同時利用計算機多個處理器核心 (CPU cores) 進行并行處理的技術,它與 Python 的多線程 (Multithreading
    的頭像 發表于 04-26 11:04 ?562次閱讀

    淺談Linux網絡編程中的多進程多線程

    在Linux網絡編程中,我們應該見過很多網絡框架或者server,有多進程的處理方式,也有多線程處理方式,孰好孰壞并沒有可比性,首先選擇多進程還是多線程我們需要考慮業務場景,其次結合當
    發表于 08-08 16:56 ?836次閱讀
    淺談Linux網絡編程中的<b class='flag-5'>多進程</b>和<b class='flag-5'>多線程</b>

    關于Python多進程多線程詳解

    進程(process)和線程(thread)是操作系統的基本概念,但是它們比較抽象,不容易掌握。關于多進程多線程,教科書上最經典的一句話是“進程
    的頭像 發表于 11-06 14:46 ?859次閱讀
    關于Python<b class='flag-5'>多進程</b>和<b class='flag-5'>多線程</b>詳解

    Linux系統上多線程多進程的運行效率

    關于多進程多線程,教科書上最經典的一句話是“進程是資源分配的最小單位,線程是CPU調度的最小單位”,這句話應付考試基本上夠了,但如果在工作中遇到類似的選擇問題,那就沒有這么簡單了,選
    的頭像 發表于 11-10 10:54 ?1429次閱讀
    Linux系統上<b class='flag-5'>多線程</b>和<b class='flag-5'>多進程</b>的運行效率

    你還是分不清多進程多線程嗎?一文搞懂!

    你還是分不清多進程多線程嗎?一文搞懂! 多進程多線程是并發編程中常見的兩個概念,它們都可以用于提高程序的性能和效率。但是它們的實現方式和使用場景略有不同。 1.
    的頭像 發表于 12-19 16:07 ?583次閱讀

    Python中多線程多進程的區別

    Python作為一種高級編程語言,提供了多種并發編程的方式,其中多線程多進程是最常見的兩種方式之一。在本文中,我們將探討Python中多線程多進程的概念、區別以及如何使用
    的頭像 發表于 10-23 11:48 ?417次閱讀
    Python中<b class='flag-5'>多線程</b>和<b class='flag-5'>多進程</b>的區別
    主站蜘蛛池模板: 国产在线精品亚洲第一区| 99热久久视频只有精品6国产| 野花日本完整版在线观看免费高清| 丰满的女朋友韩国版在线观看| 男女XX00上下抽搐动态图| 云南14学生真实初次破初视频 | 亚洲 视频 在线 国产 精品| 宝贝好紧好爽再搔一点试視頻| 免费鲁丝片一级在线观看| 最近日本字幕MV免费观看在线| 久久精品一本到东京热| 又黄又猛又爽大片免费| 久久青青热| 97色伦图区97色伦综合图区| 蜜芽视频在线观看视频免费播放| 国产小视频在线高清播放| 神马影院午夜伦理限级| 国产A级毛片久久久久久久| 体育生爆操| 国产亚洲精品字幕在线观看| 亚洲蜜桃AV永久无码精品放毛片| 精品一区二区三区在线成人| 在线播放av欧美无码碰| 免费国产成人高清在线看软件| 97在线免费观看视频| 嗯呐啊唔高H兽交| 动漫美女人物被黄漫在线看| 午夜日韩久久影院| 久久99免费视频| japanesen女同| 熟女强奷系列中文字幕| 黄色jjzz| 99久久精品6在线播放| 日韩欧美一区二区三区在线视频| 国产高清在线观看| 伊人久综合| 青青草 久久久| 国产中文字幕在线| 97人妻碰视频在线观看| 特级毛片s级全部免费| 久久艹影院|