在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

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

3天內不再提示

如何避免僵尸進程,多線程的實現原理

Q4MP_gh_c472c21 ? 來源:未知 ? 作者:李倩 ? 2018-05-31 14:37 ? 次閱讀

當一個程序開始執行后,在開始執行到執行完畢退出這段時間內,它在內存中的部分就叫稱作一個進程。

Linux 是一個多任務的操作系統,也就是說,在同一時間內,可以有多個進程同時執行。我們大家常用的單CPU計算機實際上在一個時間片段內只能執行一條指令。那么Linux是如何實現多進程的同時執行的呢?原來Linux使用了一種稱為” 進程調度 “的手段,首先,為每個進程指派一定的運行時間,這個時間通常很短,短到以毫秒為單位,然后依照某種規則,從眾多的進程中挑選一個投入運行,其他進程暫時等待,當正在運行的那個進程時間耗盡,或者執行完畢退出,或因某種原因暫停,Linux就會重新調度,挑選一個進程投入運行,因為每個進程占用的時間片段都很短,從使用者的角度來看,就好像多個進程同時運行一樣。

在Linux中,每個進程在創建的時都會被分配一個數據結構,稱為進程控制塊(PCB)。PCB中包含了很多重要的信息,供系統調度和進程本事執行使用,其中最重要的莫過于進程的ID,進程的ID也被稱為進程標示符,是一個非負的整數,在Linux操作性系統中唯一的標志一個進程。在最常使用的I386架構上,一個非負的整數的取值是0~32767,這也是我們所可能取到的進程ID,它就是進程的身份證號碼。

僵尸進程的產生

僵尸進程就是已經結束的進程,但是還沒有從進程表中刪除。僵尸進程太多會導致進程表里面條目滿了,進而導致系統崩潰,倒是不占用系統資源。

在進程的狀態中,僵尸進程是非常特殊的一種,它已經放棄了幾乎所有的內存空間,沒有任何可執行代碼,也不能被調度,僅僅在進程列表中保留一個為位置,記載該進程的退出狀態等信息供其他進程收集,除此之外,僵尸進程不再占用任何內存空間,它需要它的父進程來給它收尸,如果父進程沒安裝SIGCHLD信號處理函數調用wait或waitpid()等待子進程結束,又沒有顯示的忽略該信號,那么它就一直處于僵尸狀態。如果父進程結束了,那么init進程會自動接手這個子進程,為它收尸,他還是能夠被清除的。但是如果父進程是一個循環,不會結束,那么子進程就一直處于僵尸狀態。

僵尸進程產生的原因:

每個Linux進程在進程表中都有一個進入點(Entry),核心程序在執行該進程時使用到的一切信息都存儲在進入點。當使用ps命令查看系統中的進程信息時,看到的就是進程表中的相關數據。當fork系統調用建立一個新的進程以后,核心進程就會在進程表中給這個新進程分配一個進入點,然后將相關信息存儲在該進入點所對應的進程表中,這些信息中有一項是父進程的識別碼。當這個進程走完了自己的生命周期后,它會執行exit()系統調用,此時原來進程表中的數據會被該進程的退出碼、執行時所用的CPU時間等數據所取代,這些數據會一直保留到系統將它傳遞給它的父進程為止。由此可見,僵尸進程的出現時間實在子程序終止后,但是父進程尚未讀取這些數據之前。

如何避免僵尸進程

1、父進程通過wait和waitpid等函數等待子進程結束,這會導致父進程掛起2、如果父進程很忙,那么可以用signal函數為SIGCHLD安裝handler,因為子進程結束后,父進程會收到該信號,可以在handler中調用wait回收。3、如果父進程不關心子進程什么時候結束,那么可以用“singal(SIGCHLD),SIG_IGN”通知內核,自己對子進程的結束不感興趣,那么子進程結束后,內核會回收,并不再給父進程發送信號。4、還有一些技巧,就是fork()兩次,父進程fork一個子進程,然后繼續工作,子進程fork一個孫進程后退出,那么孫進程被init接管,孫進程結束后,init會回收,不過子進程回收還要自己做。

進程 PK 線程

我們先打個比方,多線程是十字路口多線程是平面交通系統,造價低,但是紅綠燈多,老堵車,而多進程是則是立交橋,雖然造價高,上下坡多耗油,但是不堵車。這是一個抽象的概念。相信大家看完會有這種感覺。

進程和線程是兩個相對的概念,通常來說,一個進程可以定義程序的一個實例(Instance)。在Win32中,進程并不執行什么,它只是占據應用程序所使用的地址空間。為了讓進程完成一定的工作,進程必須至少占有一個線程,正是這個線程負責包含進程地址空間中的代碼。實際上,一個進程可以包含幾個線程,它們可以同時執行進程地址空間中的代碼。為了做到這一點,每個線程有自己的一組CPU寄存器和堆棧。每個進程中至少有一個線程在執行其地址空間中的代碼。如果沒有線程執行進程地址空間中的代碼,進程也就沒有繼續存在的理由,系統將自動清除進程及其地址空間。

多線程的實現原理

創建一個進程時,它的第一個線程稱為主線程(Primary thread),由系統自動生成。然后可以由這個主線程生成額外的線程,而這些線程,又可以生成更多的線程。在運行一個多線程的程序時,從表面上看,這些線程似乎在同時運行。而實際情況并非如此,為了運行所有的這些線程,操作系統為每個獨立線程安排一些CPU時間。單CPU操作系統以時間片輪轉方式向線程提供時間片(Quantum),每個線程在使用完時間片后交出控制,系統再將CPU時間片分配給下一個線程。由于每個時間片足夠的短,這樣就給人一種假象,好像這些線程在同時運行。創建額外線程的唯一目的就是盡可能地利用CPU時間。

多線程的問題

使用多線程編程可以給程序員帶來很大的靈活性,同時也使原來需要復雜技巧才能解決的問題變得容易起來。但是,不應該人為地將編寫的程序分成一些碎片,讓這些碎片按各自的線程執行,這不是開發應用程序的正確方法。線程很有用,但當使用線程時,可能會在解決老問題的同時產生新問題。例如要開發一個字處理程序,并想讓打印功能作為單獨的線程自己執行。這聽起來是很好的主意,因為在打印時,用戶可立即返回,開始編輯文檔。但這樣一來,在該文檔被打印時文檔中的數據就有可能被修改,打印的結果就不再是所期望的內容。也許最好不要把打印功能放在單獨的線程中,不過如果一定要用多線程的話,也可以考慮用下面的方法解決:第一種方法是鎖定正在打印的文檔,讓用戶編輯其他的文檔,這樣在結束打印之前,該文檔不會作任何修改;另一個方法可能更有效一些,即可以把該文檔拷貝到一個臨時文件中,打印這個臨時文件的內容,同時允許用戶對原來的文檔進行修改。當包含文檔的臨時文件打印完成時,再刪去這個臨時文件。通過上面的分析可以看出,多線程在幫助解決問題的同時也可能帶來新問題。因此有必要弄清楚,什么時候需要創建多線程,什么時候不需要多線程。總的來說,多線程往往用于在前臺操作的同時還需要進行后臺的計算或邏輯判斷的情況。

線程的分類

在MFC中,線程被分為兩類,即工作線程和用戶界面線程。如果一個線程只完成后臺計算,不需要和用戶交互,那么可以使用工作線程;如果需要創建一個處理用戶界面的線程,則應使用用戶界面線程。這兩者的主要區別在于,MFC框架會給用戶界面線程增加一個消息循環,這樣用戶界面線程就可以處理自己消息隊列中的消息。這樣看來,如果需要在后臺作一些簡單的計算(如對電子表格的重算),則首先應考慮使用工作線程,而當后臺線程需要處理比較復雜的任務,確切地說,當后臺線程的執行過程會隨著實際情況的不同而改變時,就應該使用用戶界面線程,以便能對不同的消息作出響應。

線程的優先級

當系統需要同時執行多個進程或多個線程時,有時會需要指定線程的優先級。線程的優先級一般是指這個線程的基優先級,即線程相對于本進程的相對優先級和包含此線程的進程的優先級的結合。操作系統以優先級為基礎安排所有的活動線程,系統的每一個線程都被分配了一個優先級,優先級的范圍從0到31。運行時,系統簡單地給第一個優先級為31的線程分配CPU時間,在該線程的時間片結束后,系統給下一個優先級為31的線程分配CPU時間。當沒有優先級為31的線程時,系統將開始給優先級為30的線程分配CPU時間,以此類推。除了程序員在程序中改變線程的優先級外,有時程序在執行過程中系統也會自動地動態改變線程的優先級,這是為了保證系統對終端用戶的高度響應性。比如用戶按了鍵盤上的某個鍵時,系統就會臨時將處理WM_KEYDOWN消息的線程的優先級提高2到3。CPU按一個完整的時間片執行線程,當時間片執行完畢后,系統將該線程的優先級減1。

線程的同步

在使用多線程編程時,還有一個非常重要的問題就是線程同步。所謂線程同步是指線程之間在相互通信時避免破壞各自數據的能力。同步問題是由前面說到的Win32系統的CPU時間片分配方式引起的。雖然在某一時刻,只有一個線程占用CPU(單CPU時)時間,但是沒有辦法知道在什么時候,在什么地方線程被打斷,這樣如何保證線程之間不破壞彼此的數據就顯得格外重要。在MFC中,可以使用4個同步對象來保證多線程同時運行。它們分別是臨界區對象(CCriticalSection)、互斥量對象(CMutex)、信號量對象(CS emaphore)和事件對象(CEvent)。在這些對象中,臨界區對象使用起來最簡單,它的缺點是只能同步同一個進程中的線程。另外,還有一種基本的方法,本文稱為線性化方法,即在編程過程中對一定數據的寫操作都在一個線程中完成。這樣,由于同一線程中的代碼總是按順序執行的,就不可能出現同時改寫數據的情況。

總結:

在線程中(相對與進程而言),線程是一個更加接近執行體的概念,它可以與同進程的其他線程共享數據,但擁有自己的棧空間,擁有獨立的執行序列。這兩者都可以提高程序的并發度,提高程序運行的效率和響應的時間。線程和進程在使用上各有優缺點:線程執行開銷小,但不利于資源管理和保護;而進程正好相反。根本的區別就一點:用多進程每個進程有自己的地址空間,線程則共享地址空間,在速度方面:線程產生的速度快,線程間的通訊快,切換快等,因為他們在同一地址空間內。在資源利用率方面:線程的資源率比較好也是因為他們在同一地址空間內。 在同步方面:線程使用公共變量/內存時需要使用同步機制,因為他們在同一地址空間內進程中:子進程是父進程的復制品,子進程獲得父進程數據空間、堆和棧的復制品。

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

    關注

    4327

    文章

    23172

    瀏覽量

    400221
  • Linux
    +關注

    關注

    87

    文章

    11351

    瀏覽量

    210498
  • 線程
    +關注

    關注

    0

    文章

    507

    瀏覽量

    19763

原文標題:Linux系統進程的一些知識總結,進程與線程之間的糾葛...

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

收藏 人收藏

    評論

    相關推薦

    Java多線程的用法

    能力。 什么是進程 是指正在運行的程序的實例。 每個進程都擁有自己的內存空間、代碼、數據和文件等資源,可以獨立運行、調度和管理。在操作系統中,進程是系統資源分配的最小單位,是實現多任務
    的頭像 發表于 09-30 17:07 ?1013次閱讀

    孤兒進程僵尸進程

    前段時間,由于研究經典面試題,把孤兒進程僵尸進程也總結了一下。我們有這樣一個問題:孤兒進程僵尸進程
    發表于 11-29 14:08

    進程線程區別

    )。不管是多進程還是多線程,最終目標都是實現并行執行。 2、多線程的優勢前些年多進程多一些,近些年多線程
    發表于 11-30 14:06

    多線程和多進程的區別

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

    淺談多進程多線程的選擇

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

    進程有幾種狀態?

    文章目錄操作系統進程線程什么是進程?什么是線程進程線程有什么區別?何時使用多
    發表于 12-24 07:16

    python多線程和多進程對比

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

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

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

    進程多線程的深度比較

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

    Linux下的多線程編程

    進程(process)中只允許有一個線程,這樣多線程就意味著多進程。現在,多線程技術已經被許多操作系統所支持,包括Windows/NT,當然
    發表于 04-02 14:43 ?641次閱讀

    SpringBoot實現多線程

    SpringBoot實現多線程
    的頭像 發表于 01-12 16:59 ?1897次閱讀
    SpringBoot<b class='flag-5'>實現</b><b class='flag-5'>多線程</b>

    關于Python多進程多線程詳解

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

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

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

    Python中多線程和多進程的區別

    Python作為一種高級編程語言,提供了多種并發編程的方式,其中多線程與多進程是最常見的兩種方式之一。在本文中,我們將探討Python中多線程與多進程的概念、區別以及如何使用
    的頭像 發表于 10-23 11:48 ?500次閱讀
    Python中<b class='flag-5'>多線程</b>和多<b class='flag-5'>進程</b>的區別

    socket 多線程編程實現方法

    是指在同一個進程中運行多個線程,每個線程可以獨立執行任務。線程共享進程的資源,如內存空間和文件句柄,但每個
    的頭像 發表于 11-12 14:16 ?479次閱讀
    主站蜘蛛池模板: 国产精品爽爽影院在线 | 日本三级黄 | 激情综合视频 | 四虎永久免费在线 | 天天色国产 | 四虎www成人影院观看 | 三级黄色在线观看 | 久久亚洲精品国产精品婷婷 | 亚洲区一二三四区2021 | 日韩在线影院 | 黄色网址免费在线 | 视频一区二区在线播放 | 99精品在免费线视频 | 狠狠色噜噜狠狠狠狠97 | 欧美综合久久 | 久久伊人成人 | 亚洲伊人久久大香线蕉结合 | 午夜免费福利视频 | 日本69xxxxxxx69| 欧美在线高清视频 | dy888午夜秋霞影院不卡 | 亚洲精品老司机综合影院 | 免费黄色国产视频 | 99热最新在线 | 国产成人99久久亚洲综合精品 | 国产美女亚洲精品久久久综合 | 国产午夜视频在线观看网站 | 99热网站 | 美女视频黄视大全视频免费网址 | 免费香蕉视频国产在线看 | se色综合视频 | 久久精品视频7 | 天天爽夜夜| 自拍偷自拍亚洲精品被多人伦好爽 | 天堂网最新版中文 | 米奇久久| 99精品在免费线视频 | 全部免费特黄特色大片视频 | 免费观看一区二区 | 国产九色在线 | 国产成人精品曰本亚洲77美色 |