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

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

3天內不再提示

淺析OS中的線程、進程和協程與RTOS任務屬于那種

strongerHuang ? 來源:CSDN技術社區 ? 作者:最后一個bug ? 2021-04-19 10:06 ? 次閱讀

今天為大家講解講解OS中的線程、進程和協程的這幾個概念,同時一起看看RTOS中的任務到底屬于哪一種。

1、三者整體關系圖

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

98d01e38-9ff4-11eb-8b86-12bb97331649.png

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

98dc8b14-9ff4-11eb-8b86-12bb97331649.png

2、詳細分析一下

1)并發與并行

在講解進程之前我們先看看并發與并行的概念,并發字面上的意思就是一起發生,在乎的是一種感覺,對于單核CPU而言其對指令的處理都是順序執行,只是說類似于一種時間上分時交替處理,給用戶的一同發生的表象,這就是并發。

并行是指令同一時刻一起運行,這種方式一般在多處理器系統中發生。

98e63f38-9ff4-11eb-8b86-12bb97331649.png

2) 進 程

進程是一種程序的動態執行過程,進程對CPU并不是獨占連續執行的,OS管理著進程需要經常打斷當前的進程,并對多個進程進行監控調度等,那么在內核中就有一個結構體叫做進程控制塊PCB(學RTOS應該聽過任務控制塊TCB,后面會提到)-(Process Control Block),該結構體包含了該進程幾乎所有的信息和資源,那么OS也就是通過這個控制塊來獲得進程信息并管理進程。

98eef6aa-9ff4-11eb-8b86-12bb97331649.png

進程的設計是為了讓各個應用程序能夠更好的進行隔離,比如在瀏覽網頁突然瀏覽器奔潰了這不會影響到我的音樂播放器,前面作者發布的OS對內存的管理可以了解到每個進程都會有自己獨立的內存空間,并且通過內存管理模塊MMU和頁表機制各個進程之間形成了隔離。

如果進行多進程的并發勢必需要保存當前進程現場信息,比如寄存器,堆棧,更新頁表,甚至還需要從外存(比如磁盤中)置換出進程進行運行,這樣對于CPU的開銷非常大,于是為了減少開銷便有了進程內的并發線程。

3) 線 程

進程的目的是隔離并發,可以說線程是實現的共享并發,所有的線程都是共用屬于進程的資源,線程是進程指令流的剝離,同樣線程有對應的結構體信息管理TCB類似于RTOS中的TCB。

993e5c5e-9ff4-11eb-8b86-12bb97331649.png

由于線程資源共享,所以各個線程之間是會存在相互的影響,如果一個線程出現奔潰混亂,極大可能會影響到該進程中的其他線程;同時對于共享資源的讀寫也就會存在競爭問題,那么這樣就產生了一系列的共享資源的處理辦法,臨界區,互斥信號等等。

同時現在目前大部分OS其線程的管理、調度和并發都是通過內核了完成的,這樣就會存在較多系統調用以及從用戶態到內核態的切換,都會消耗一些時間,為了更進一步減少開銷,直接在用戶態實現更好的并發就出現了協程概念。

4) 協 程

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

99601aec-9ff4-11eb-8b86-12bb97331649.png

協程的特點:

協程是用戶態執行的并發,相對線程開銷要??;

協程主動放棄占用,對相關資源不需要進行鎖處理;

非常適合IO密集型任務,比如非常經典的生產者與消費者的雙線程模式,如果用協程,生產出來以后立馬讓步給消費者進行處理,效率非常高。

3、RTOS任務屬于多線程

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

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

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

4、最后小節

可能部分小伙伴對于這幾個概念還有諸多疑惑,其并不是對這幾個概念不理解而是對OS的運行原理有些迷惑,所以大家對這部分感興趣也可以查找相關書籍進行系統的學習,加油!
編輯:lyn

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

    關注

    20

    文章

    781

    瀏覽量

    118901
  • 線程
    +關注

    關注

    0

    文章

    496

    瀏覽量

    19537
  • 進程
    +關注

    關注

    0

    文章

    196

    瀏覽量

    13905

原文標題:RTOS中的任務是線程、進程、還是協程?

文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    一句話讓你理解線程進程

    ,比如QQ、微信、瀏覽器等;?個應?程序也可以同時運?多個進程,比如同時打開兩個QQ、瀏覽器。線程:1個進程(應用程序)可能需要同時執行幾個任務,比如QQ可以同時視頻
    的頭像 發表于 06-04 08:04 ?458次閱讀
    一句話讓你理解<b class='flag-5'>線程</b>和<b class='flag-5'>進程</b>

    基于RTOS的應用進程中的典型線程

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

    線程是什么的基本單位 進程線程的本質區別

    的代碼、數據以及用于執行這些代碼的上下文信息。一個進程可以由一個或多個線程組成,從而并發執行多個任務。 本質區別: 資源擁有方式:進程是資源分配的基本單位,每個
    的頭像 發表于 02-02 16:30 ?424次閱讀

    mcu線程進程的區別是什么

    MCU線程進程是嵌入式系統中常見的并行執行的概念,它們之間有許多區別,包括線程進程的定義、資源管理、通信機制、執行方式等等。下面將詳細介紹MCU
    的頭像 發表于 01-04 10:45 ?355次閱讀

    Linux中進程、線程和協程的基礎概念

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

    如何設定RTOS中的任務棧(線程棧)大小呢?

    首先說明的是,在 `RT-Thread` 中,將本文提及的 `任務` 稱之為 `線程`。
    的頭像 發表于 12-01 16:40 ?868次閱讀

    RTOS內功修煉記(一)— 任務到底應該怎么寫?

    本篇文章講述了任務的三大元素:任務控制塊、任務棧、任務入口函數,并講述了編寫RTOS任務入口函數
    的頭像 發表于 12-01 16:36 ?405次閱讀
    <b class='flag-5'>RTOS</b>內功修煉記(一)— <b class='flag-5'>任務</b>到底應該怎么寫?

    進程線程的概念及其區別

    今天浩道跟大家分享一篇關于進程線程之間關聯的硬核干貨,看看大神如何通過通俗易懂的圖文,讓大家更加深刻理解進程線程的區別!
    的頭像 發表于 11-21 10:50 ?626次閱讀
    <b class='flag-5'>進程</b>和<b class='flag-5'>線程</b>的概念及其區別

    JDK如何優雅退出一個線程?

    需要線程退出的常見場景 任務執行完成,或異常終止,任務認為無需再占用線程。 線程池根據當前任務
    的頭像 發表于 11-17 10:02 ?275次閱讀
    JDK如何優雅退出一個<b class='flag-5'>線程</b>?

    RTOS中的線程、進程和協程詳解

    看到有小伙伴在討論【RTOS任務屬于線程還是進程】的話題,這里就來分析一下OS中的
    的頭像 發表于 11-09 12:36 ?1123次閱讀
    <b class='flag-5'>RTOS</b>中的<b class='flag-5'>線程</b>、<b class='flag-5'>進程</b><b class='flag-5'>和協</b>程詳解

    關于Python多進程和多線程詳解

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

    STM32 RTOS介紹

    R(real) T(time) OS 實時多任務操作系統、RTOS是一種操作系統,屬于嵌入式操作系統,RTOS種類很多:有商業的、DIY和開
    發表于 09-07 08:08

    RealView調試器4.1版RTOS指南

    包含有關程序資源和執行狀態的信息,例如程序指令、堆棧和堆。 進程使用共享內存或工具(如隊列、信號量或管道)進行通信。 獨立運行的線程可能是進程的一部分,這些線程共享資源,但可以由操作系
    發表于 08-12 07:16

    進程線程的區別以及優缺點

    進程線程 1、什么是進程、線程,有什么區別? 進程是資源(CPU、內存等)分配的基本單位,線程
    的頭像 發表于 07-21 11:02 ?958次閱讀

    程序中進程線程的區別

    什么是進程 1、進程線程的區別 進程是指正在運行的程序,它擁有獨立的內存空間和系統資源,不同進程之間的數據不共享。
    的頭像 發表于 06-22 11:39 ?354次閱讀
    程序中<b class='flag-5'>進程</b>和<b class='flag-5'>線程</b>的區別
    亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
    <acronym id="s8ci2"><small id="s8ci2"></small></acronym>
    <rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
    <acronym id="s8ci2"></acronym>
    <acronym id="s8ci2"><center id="s8ci2"></center></acronym>