chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

3天內(nèi)不再提示

一文深入淺出了解進程和線程

如意 ? 來源:CSDN ? 作者:Peter盼 ? 2020-06-20 10:45 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

No.1

執(zhí)行流

這里先說一說執(zhí)行流,有助于線程的理解。

程序計數(shù)器中的下一條指令地址組成的軌跡稱為程序的執(zhí)行流。執(zhí)行流是邏輯上獨立的指令區(qū)域,是人為給處理器安排的處理單元。指令指導處理器的執(zhí)行方向,從處理器的角度看,執(zhí)行的指令形成一條路徑,稱為執(zhí)行流。執(zhí)行流可大可小,可以是整個程序文件,也可以是一個函數(shù)。

一個代碼段想要突然去執(zhí)行另外一個代碼段的指令,比如call指令或者因中斷去執(zhí)行中斷處理程序,只要先將調用前或中斷前的上下文環(huán)境保存好就可以在iret或中斷返回后繼續(xù)執(zhí)行原代碼段的指令。所以說當我們?yōu)槿魏我欢沃噶钐峁┧枰纳舷挛沫h(huán)境,那么這段指令就可以在獨立的上CPU運行,也就是說這段指令成為了一個單獨的執(zhí)行流。這里說的上下文環(huán)境指的是指令所使用的寄存器映像、棧、內(nèi)存等資源。可以獨立在CPU上運行的代碼段,哪怕被中斷也可以返回繼續(xù)執(zhí)行,因為它所需要的資源得到了維護。

在任務調度器的眼里,執(zhí)行流是調度單元,即處理器上運行的每個任務都是調度器分配的執(zhí)行流。換句話說,實現(xiàn)任務調度,就是換不同的執(zhí)行流在CPU上運行。我們要說的線程就是一個執(zhí)行流。進程和線程有很多相似的地方,當一個進程中只有一個線程時,我們稱之為單線程進程,它比線程就只多了處理的資源。我們可以認為線程和進程都是由執(zhí)行流實現(xiàn)的。

No.2

線程

回想創(chuàng)建線程的過程,我們先聲明并定義一個函數(shù)作為線程的處理函數(shù),該函數(shù)的返回值為void*參數(shù)也是void*,然后調用pthread_create()函數(shù)創(chuàng)建線程。可以理解為線程就是去執(zhí)行一個函數(shù),但線程和普通的函數(shù)的區(qū)別在于線程擁有獨立的上下文環(huán)境成為了獨立的執(zhí)行流,也就成為了獨立的調度單元,可以獨立在CPU上運行。在一般的函數(shù)調用中,函數(shù)隨著程序的執(zhí)行流被順便執(zhí)行。給每個執(zhí)行流分配的時間是有限的,一個普通函數(shù)要等到該它運行的時候才可以在CPU上運行,前面有再多的函數(shù)它都要等著,還沒有到它運行的時候可能該執(zhí)行流就被換下CPU了。而線程則因為成了單獨的執(zhí)行流,可以獨自享用分配的CPU時間,這才是線程真正優(yōu)勢的地方。

只有理解了線程的優(yōu)勢,在使用線程的時候才能恰到好處,現(xiàn)在再回想自己寫的多線程程序是否真的需要使用多線程。將要處理的單獨一類事件放在一個執(zhí)行流等待就好了,沒有必要寫成多線程,在調度器調度的時候反而會花費額外的時間。

線程是一套機制,給一段代碼塊構建它依賴的上下文環(huán)境,從而讓代碼塊稱為單獨的執(zhí)行流,也就成為了調度器的調度單元可以直接在CPU運行。

線程中調用的函數(shù)讓所運行的函數(shù)以調度單元的身份獨立運行在CPU上,當函數(shù)運行時,可以讓程序中多個函數(shù)(執(zhí)行流)以偽并行的方式運行,為程序提速。

No.3

線程與進程

進程是運行中的程序。對于處理器來說,進程是執(zhí)行流的集合,至少包含一個執(zhí)行流,執(zhí)行流之間相互獨立,但它們共享進程的所有資源。

Linux早期版本(Linux 0.11),其中并沒有操作系統(tǒng)書籍說到的有關線程的代碼,比如thread_info結構體和創(chuàng)建線程的函數(shù)。那時CPU調度的單元是進程,進程就是各個執(zhí)行流(調度單元),這里想說明的是進程和線程都是概念上的。在線程出現(xiàn)之前依然能夠實現(xiàn)并發(fā)處理,線程在進程的基礎上實現(xiàn)了二次并發(fā),目的是提高效率。進程與線程的區(qū)別,一個是上面所說的進程中可以有多個線程。第二個就是線程沒有自己的資源,沒有自己的地址空間,必須要依附于進程的地址空間中才可以運行。

No.4

進程線程的狀態(tài)

上面說了進程和線程是概念上的,真正實現(xiàn)時都是人為創(chuàng)造的代碼塊,因此執(zhí)行流的狀態(tài)也是人為劃分的。比如因為有的線程在讀寫磁盤時需要等待,那么就需要該線程為阻塞狀態(tài),當線程可以上CPU運行時該線程就叫就緒態(tài),在CPU運行時就稱為運行態(tài)。在有其他需求的時候可能還會由別的狀態(tài)出現(xiàn),只要合理就可以,說明狀態(tài)都是因為某種需求而出現(xiàn)的,然后當狀態(tài)滿足后就說明線程符合了某些條件,比如線程由阻塞態(tài)變?yōu)榫途w態(tài)說明現(xiàn)在線程可能正在等待的資源已經(jīng)等到了可以上CPU運行了。

No.5

程序控制塊PCB

PCB(Process Control Block)是進程的身份證,記錄了與進程相關的所有信息,比如進程狀態(tài)、PID、優(yōu)先級等。每個進程都有自己的一個PCB。所有PCB放到一張表格中維護,就是進程表,調度器根據(jù)這張表選擇上處理器運行的進程。PCB的內(nèi)容取決于操作系統(tǒng)功能的復雜程度。PCB可以確定處理器要執(zhí)行的任務,記錄程序運行時所需要的數(shù)據(jù)資源、給任務分配的時間大小、上下文信息的存儲地址、進程狀態(tài)、進程地址空間等信息。

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

    關注

    0

    文章

    508

    瀏覽量

    20655
  • 進程
    +關注

    關注

    0

    文章

    208

    瀏覽量

    14451
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    ALM(應用生命周期管理)解析:了解其概念、關鍵階段及Perforce ALM工具推薦

    什么是ALM(應用生命周期管理)?它遠不止是SDLC!了解其概念、關鍵階段以及如何借助Perforce ALM這類工具,實現(xiàn)端到端的可追溯性、加速發(fā)布并保障合規(guī)性。
    的頭像 發(fā)表于 09-19 11:03 ?585次閱讀
    ALM(應用生命周期管理)解析:<b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>了解</b>其概念、關鍵階段及Perforce ALM工具推薦

    【HZ-T536開發(fā)板免費體驗】—— linux創(chuàng)建線程

    線程進程 進程指的是個正在執(zhí)行的應用程序,而線程的功能是執(zhí)行應用程序中的某個具體任務。
    發(fā)表于 09-01 21:31

    了解電壓諧波

    我們經(jīng)常會聽到諧波,到底什么是諧波,怎么定義的?為什么要關注諧波?什么時候關注諧波?諧波如何計算或標準規(guī)定的諧波的算法是怎樣的?GB關于電壓諧波又是如何評估的?帶著諸多的問題,我們一起來了解。
    的頭像 發(fā)表于 06-28 17:23 ?3314次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b><b class='flag-5'>了解</b>電壓諧波

    程序設計與數(shù)據(jù)結構

    的地址)出發(fā),采用推導的方式,深入淺出的分析了廣大C程序員學習和開發(fā)中遇到的難點。 2. 從方法論的高度對C語言在數(shù)據(jù)結構和算法方面的應用進行了深入講解和闡述。 3. 講解了絕大多數(shù)C程序員開發(fā)
    發(fā)表于 05-13 16:45

    全面解析新概念模擬電路(建議下載?。?/a>

    全文共五冊,近50萬字,樣的風趣幽默,樣的social化語言,深入淺出地將枯燥深奧的模電知識講得簡單易學。 《新概念模擬電路》內(nèi)容包含了《晶體管》、《負反饋和運算放大器》、《運放電路的頻率特性
    發(fā)表于 04-16 13:37

    深入淺出解析低功耗藍牙協(xié)議棧

    深入Bluetooth LE協(xié)議棧各個組成部分之前,我們先看下Bluetooth LE協(xié)議棧整體架構。 如上圖所述,要實現(xiàn)個Bluetooth LE應用,首先需要個支持Bluet
    的頭像 發(fā)表于 04-09 14:49 ?825次閱讀
    <b class='flag-5'>深入淺出</b>解析低功耗藍牙協(xié)議棧

    進程、線程、協(xié)程傻傻分不清?帶你徹底扒光它們的\"底褲\"!

    它們就像程序界的「三國演義」: 進程:曹魏政權(獨占資源,穩(wěn)如老狗) 線程:孫劉聯(lián)軍(共享資源,相愛相殺) 協(xié)程:諸葛亮北伐(人帶十軍,靠的是「空城計」) 第章:
    發(fā)表于 03-26 09:27

    《零基礎開發(fā)AI Agent——手把手教你用扣子做智能體》

    《零基礎開發(fā)AI Agent——手把手教你用扣子做智能體》是本為普通人量身打造的AI開發(fā)指南。它不僅深入淺出地講解了Agent的概念和發(fā)展,還通過詳細的工具介紹和實戰(zhàn)案例,幫助讀者快速掌握
    發(fā)表于 03-18 12:03

    請問如何在Python中實現(xiàn)多線程與多進程的協(xié)作?

    大家好!我最近在開發(fā)個Python項目時,需要同時處理多個任務,且每個任務需要不同的計算資源。我想通過多線程和多進程的組合來實現(xiàn)并發(fā),但遇到了些問題。 具體來說,我有兩個任務,
    發(fā)表于 03-11 06:57

    深入解析Linux程序與進程

    什么是程序 組計算機能識別和執(zhí)行的指令,用于指導計算機執(zhí)行特定任務或解決特定問題。程序通常由代碼、數(shù)據(jù)和資源文件組成,涉及語法、算法和數(shù)據(jù)結構。為二進制文件 什么是進程個具有獨立功能的程序
    的頭像 發(fā)表于 12-18 11:01 ?729次閱讀
    <b class='flag-5'>深入</b>解析Linux程序與<b class='flag-5'>進程</b>

    掌握基礎電路,嵌入式開發(fā)深入淺出

    1. 電路知識 1.1.?驅動能力 IC是數(shù)字邏輯芯片,其輸出的是邏輯電平。邏輯電平0表示輸出電壓低于閾值電壓,邏輯1表示輸出電壓高于閾值電壓。負載則是被驅動的電路或元件,負載大小則指負載的電阻大小。 驅動能力主要表現(xiàn)在幾個方面: 負載能力:負載過大表現(xiàn)為外部負載的阻值過小,在電壓不變的情況下,過小的阻值會導致電流過大,可能會燒壞器件。負載過小,表現(xiàn)為外部負載的阻值達大,在電壓不變的情況下,過大的阻值會導致電流過小,信
    的頭像 發(fā)表于 12-03 10:36 ?1193次閱讀
    <b class='flag-5'>一</b><b class='flag-5'>文</b>掌握基礎電路,嵌入式開發(fā)<b class='flag-5'>深入淺出</b>

    深入淺出RISC-V調試

    、JTAG簡介 目前RISC-V官方支持的調試方式是JTAG(Joint Test Action Group),而ARM支持的調試方式有JTAG和SWD(Serial Wire Debug)這兩種
    發(fā)表于 11-28 22:00

    socket 多線程編程實現(xiàn)方法

    是指在同進程中運行多個線程,每個線程可以獨立執(zhí)行任務。線程共享進程的資源,如內(nèi)存空間和文件句
    的頭像 發(fā)表于 11-12 14:16 ?1338次閱讀

    搞懂Linux進程的睡眠和喚醒

    。通過PPID,可以追蹤進程的來源,并了解進程之間的關系。 在PCB中記錄的進程狀態(tài),不過是些整數(shù),這個整數(shù)是多少就代表
    發(fā)表于 11-04 15:15

    Python中多線程和多進程的區(qū)別

    Python作為種高級編程語言,提供了多種并發(fā)編程的方式,其中多線程與多進程是最常見的兩種方式之。在本文中,我們將探討Python中多線程
    的頭像 發(fā)表于 10-23 11:48 ?1232次閱讀
    Python中多<b class='flag-5'>線程</b>和多<b class='flag-5'>進程</b>的區(qū)別