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

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

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

RTOS中的線程、進程和協(xié)程詳解

strongerHuang ? 來源:strongerHuang ? 2023-11-09 12:36 ? 次閱讀

轉(zhuǎn)自 |最后一個bug

看到有小伙伴在討論【RTOS任務(wù)屬于線程還是進程】的話題,這里就來分析一下OS中的線程、進程和協(xié)程的這幾個概念,同時一起看看RTOS中的任務(wù)到底屬于哪一種。

三者關(guān)系

很多小伙伴在學(xué)習(xí)OS的過程中會遇到各種程序形態(tài),比如說進程、線程、協(xié)程、管程、纖程,oh my god!要是對他們不熟悉還真分辨不清楚,今天作者主要是把大家平時最常遇到的進程、線程和協(xié)程這三個概念講一講,其他形態(tài)作者后續(xù)再慢慢補充相關(guān)文章,下面我們簡單看一下windows里面的進程(Linux也是類似的),如下圖所示:

e3ec001c-7eae-11ee-939d-92fbcf53809c.png

我們可以發(fā)現(xiàn)每行表示一個進程,同時一個進程包含多個線程,那么進程、線程和協(xié)程的關(guān)系到底是怎樣的呢?作者這里畫了個簡圖,供大家參考。

e3f874f0-7eae-11ee-939d-92fbcf53809c.png

對比分析

1)并發(fā)與并行

在講解進程之前我們先看看并發(fā)與并行的概念,并發(fā)字面上的意思就是一起發(fā)生,在乎的是一種感覺,對于單核CPU而言其對指令的處理都是順序執(zhí)行,只是說類似于一種時間上分時交替處理,給用戶的一同發(fā)生的表象,這就是并發(fā)。 并行是指令同一時刻一起運行,這種方式一般在多處理器系統(tǒng)中發(fā)生。

e405e72a-7eae-11ee-939d-92fbcf53809c.png

2) 進 程

進程是一種程序的動態(tài)執(zhí)行過程,進程對CPU并不是獨占連續(xù)執(zhí)行的,OS管理著進程需要經(jīng)常打斷當(dāng)前的進程,并對多個進程進行監(jiān)控調(diào)度等,那么在內(nèi)核中就有一個結(jié)構(gòu)體叫做進程控制塊PCB(學(xué)RTOS應(yīng)該聽過任務(wù)控制塊TCB,后面會提到)-(Process Control Block),該結(jié)構(gòu)體包含了該進程幾乎所有的信息和資源,那么OS也就是通過這個控制塊來獲得進程信息并管理進程。

e417ca9e-7eae-11ee-939d-92fbcf53809c.png

進程的設(shè)計是為了讓各個應(yīng)用程序能夠更好的進行隔離,比如在瀏覽網(wǎng)頁突然瀏覽器奔潰了這不會影響到我的音樂播放器,前面作者發(fā)布的OS對內(nèi)存的管理可以了解到每個進程都會有自己獨立的內(nèi)存空間,并且通過內(nèi)存管理模塊MMU和頁表機制各個進程之間形成了隔離。 如果進行多進程的并發(fā)勢必需要保存當(dāng)前進程現(xiàn)場信息,比如寄存器,堆棧,更新頁表,甚至還需要從外存(比如磁盤中)置換出進程進行運行,這樣對于CPU的開銷非常大,于是為了減少開銷便有了進程內(nèi)的并發(fā)線程。

3)線 程

進程的目的是隔離并發(fā),可以說線程是實現(xiàn)的共享并發(fā),所有的線程都是共用屬于進程的資源,線程是進程指令流的剝離,同樣線程有對應(yīng)的結(jié)構(gòu)體信息管理TCB類似于RTOS中的TCB。

e42052b8-7eae-11ee-939d-92fbcf53809c.png

由于線程資源共享,所以各個線程之間是會存在相互的影響,如果一個線程出現(xiàn)奔潰混亂,極大可能會影響到該進程中的其他線程;同時對于共享資源的讀寫也就會存在競爭問題,那么這樣就產(chǎn)生了一系列的共享資源的處理辦法,臨界區(qū),互斥信號等等。 同時現(xiàn)在目前大部分OS其線程的管理、調(diào)度和并發(fā)都是通過內(nèi)核了完成的,這樣就會存在較多系統(tǒng)調(diào)用以及從用戶態(tài)到內(nèi)核態(tài)的切換,都會消耗一些時間,為了更進一步減少開銷,直接在用戶態(tài)實現(xiàn)更好的并發(fā)就出現(xiàn)了協(xié)程概念。

4) 協(xié) 程

之前的總覽關(guān)系圖我們也知道一個線程里面可以運行多個協(xié)程,其實函數(shù)調(diào)用就是一種狀態(tài)為初態(tài)的協(xié)程,A函數(shù)中調(diào)用B函數(shù),可以認為是A任務(wù)切換到B任務(wù)來執(zhí)行,然后執(zhí)行完回到A任務(wù),不過這樣調(diào)用的任務(wù)始終是從初始狀態(tài)開始,如果一個函數(shù)主動放棄CPU通過保存當(dāng)前現(xiàn)場,比如寄存器值等,然后恢復(fù)到另外一個函數(shù)的寄存器狀態(tài),便實現(xiàn)了任意狀態(tài)函數(shù)的并發(fā)執(zhí)行,就實現(xiàn)了協(xié)程。好吧,解釋得有點繞,畫個圖理解理解:

e42ee2f6-7eae-11ee-939d-92fbcf53809c.png

協(xié)程的特點:

協(xié)程是用戶態(tài)執(zhí)行的并發(fā),相對線程開銷要??;

協(xié)程主動放棄占用,對相關(guān)資源不需要進行鎖處理;

非常適合IO密集型任務(wù),比如非常經(jīng)典的生產(chǎn)者與消費者的雙線程模式,如果用協(xié)程,生產(chǎn)出來以后立馬讓步給消費者進行處理,效率非常高。

RTOS任務(wù)屬于多線程

對于目前主流的RTOS,比如ucos,freeRTOS,RT-thread等等,都是屬于并發(fā)的線程,其實從RT-thread名字上看,其表示的就是實時的線程。

首先對于MCU上的資源每個任務(wù)都是共享的,可以認為是單進程多線程模型。

MCU一般沒有內(nèi)存管理模塊MMU等等,這樣無法很好的實現(xiàn)進程的安全,如果用軟件實現(xiàn),開銷太大,對于MCU沒有太多的必要,這也是為什么我們當(dāng)個任務(wù)程序跑飛會導(dǎo)致整個程序無法運行的原因。

審核編輯:湯梓紅

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

    關(guān)注

    146

    文章

    16885

    瀏覽量

    349918
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11207

    瀏覽量

    208717
  • RTOS
    +關(guān)注

    關(guān)注

    21

    文章

    809

    瀏覽量

    119361
  • 線程
    +關(guān)注

    關(guān)注

    0

    文章

    503

    瀏覽量

    19636
  • 進程
    +關(guān)注

    關(guān)注

    0

    文章

    201

    瀏覽量

    13938

原文標(biāo)題:RTOS任務(wù)屬于線程、進程、還是協(xié)程?

文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    進程線程的區(qū)別

    系統(tǒng)對應(yīng)用的并發(fā)性。進程線程的區(qū)別在于:簡而言之,一個程序至少有一個進程,一個進程至少有一個線程.
    發(fā)表于 12-12 09:28

    進程線程的區(qū)別和聯(lián)系介紹

    的操作系統(tǒng),通常一個進程都有若干個線程,至少需要一個線 。下面,我們從調(diào)度、并發(fā)性、 系統(tǒng)開銷、擁有資源等方面,來比較線程
    發(fā)表于 07-04 00:18

    請問uCOS-II的任務(wù)是進程還是線程?

    的基本單位。線程自己基本上不擁有系統(tǒng)資源,只擁有一點在運行必不可少的資源(如程序計數(shù)器,一組寄存器和棧),但是它可與同屬一個進程的其他的線程共享
    發(fā)表于 06-03 05:07

    協(xié)線程有什么區(qū)別

    協(xié)線程的區(qū)別協(xié)線程的共同目的之一是實現(xiàn)系統(tǒng)資源的上下文調(diào)用,不過它們的實現(xiàn)層級不同;線程(Thraed)是比
    發(fā)表于 12-10 06:23

    進程線程定義

    線程是CPU調(diào)度的最小單位(程序執(zhí)行流的最小單元),它被包含在進程之中,是進程的實際運作單元。一條線程
    的頭像 發(fā)表于 11-20 10:23 ?2613次閱讀

    線程進程的關(guān)系與區(qū)別

    線程是CPU調(diào)度的最小單位(程序執(zhí)行流的最小單元),它被包含在進程之中,是進程的實際運作單元。一條線程
    的頭像 發(fā)表于 11-29 11:01 ?1.3w次閱讀

    進程線程分別是什么,它們的區(qū)別是什么

    線程的區(qū)別是什么?有什么關(guān)系?相信大家對于進程都很熟悉了吧,而線程相對于進程而言,是一個更加接近于執(zhí)行體的概念,為了讓大家更好的了解
    發(fā)表于 03-24 17:26 ?9359次閱讀
    <b class='flag-5'>進程</b>和<b class='flag-5'>線程</b>分別是什么,它們的區(qū)別是什么

    淺析OS線程、進程和協(xié)RTOS任務(wù)屬于那種

    今天為大家講解講解OS線程進程和協(xié)的這幾個概念,同時一起看看RTOS
    的頭像 發(fā)表于 04-19 10:06 ?3137次閱讀
    淺析OS<b class='flag-5'>中</b>的<b class='flag-5'>線程</b>、<b class='flag-5'>進程</b><b class='flag-5'>和協(xié)</b><b class='flag-5'>程</b>與<b class='flag-5'>RTOS</b>任務(wù)屬于那種

    Linux下線程進程的區(qū)別

    線程(英語:thread)是操作系統(tǒng)能夠進行運算調(diào)度的最小單位。它被包含在進程之中,是進程的實際運作單位。一條線程指的是
    的頭像 發(fā)表于 08-24 15:37 ?1818次閱讀
    Linux下<b class='flag-5'>線程</b>與<b class='flag-5'>進程</b>的區(qū)別

    詳解Linux線程、線程與異步編程、協(xié)與異步

    協(xié)不是系統(tǒng)級線程,很多時候協(xié)被稱為“輕量級線程”、“微線程”、“纖(fiber)”等。簡單
    的頭像 發(fā)表于 03-16 15:49 ?932次閱讀

    RTOS的任務(wù)是線程?進程?還是協(xié)?

    今天為大家講解講解OS線程、進程和協(xié)的這幾個概念,同時一起看看RTOS
    的頭像 發(fā)表于 06-04 17:19 ?1610次閱讀
    <b class='flag-5'>RTOS</b><b class='flag-5'>中</b>的任務(wù)是<b class='flag-5'>線程</b>?<b class='flag-5'>進程</b>?還是協(xié)<b class='flag-5'>程</b>?

    關(guān)于Python多進程和多線程詳解

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

    Linux中進程、線程和協(xié)的基礎(chǔ)概念

    進程是計算機運行的程序的實例,它是操作系統(tǒng)中最基本的執(zhí)行單元之一。每個進程都有自己的獨立內(nèi)存空間、系統(tǒng)資源和代碼執(zhí)行流。這意味著一個進程的崩潰通常不會影響其他
    的頭像 發(fā)表于 12-06 09:22 ?748次閱讀

    基于RTOS的應(yīng)用進程的典型線程

    RTOS的關(guān)鍵因素是最小的中斷延遲和最小的線程切換延遲。RTOS的價值在于它的響應(yīng)速度或可預(yù)測性,而不是它在給定時間段內(nèi)可以執(zhí)行的工作量。
    發(fā)表于 03-05 09:32 ?498次閱讀
    基于<b class='flag-5'>RTOS</b>的應(yīng)用<b class='flag-5'>進程</b><b class='flag-5'>中</b>的典型<b class='flag-5'>線程</b>

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

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