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

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

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

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

淺析OS中的線程、進(jìn)程和協(xié)程與RTOS任務(wù)屬于那種

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

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

1、三者整體關(guān)系圖

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

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

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

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

2、詳細(xì)分析一下

1)并發(fā)與并行

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

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

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

2) 進(jìn) 程

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

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

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

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

3) 線 程

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

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

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

同時現(xiàn)在目前大部分OS其線程的管理、調(diào)度和并發(fā)都是通過內(nèi)核了完成的,這樣就會存在較多系統(tǒng)調(diào)用以及從用戶態(tài)到內(nèi)核態(tài)的切換,都會消耗一些時間,為了更進(jìn)一步減少開銷,直接在用戶態(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ù),可以認(rèn)為是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é)程。好吧,解釋得有點繞,畫個圖理解理解:

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

協(xié)程的特點:

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

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

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

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

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

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

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

4、最后小節(jié)

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

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

    關(guān)注

    24

    文章

    845

    瀏覽量

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

    關(guān)注

    0

    文章

    507

    瀏覽量

    20109
  • 進(jìn)程
    +關(guān)注

    關(guān)注

    0

    文章

    207

    瀏覽量

    14239

原文標(biāo)題:RTOS中的任務(wù)是線程、進(jìn)程、還是協(xié)程?

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

收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    RTOS如何在FX3工作?

    大家好, 我正在使用 FX3 進(jìn)行一個項目。 我想知道 RTOS 調(diào)度是如何工作的。 我知道調(diào)用“CyU3PKernelEntry();”后 RTOS 就會開始工作。 如果我只注冊一個應(yīng)用程序線程。 我的
    發(fā)表于 05-06 13:20

    LuatOS協(xié)深度解析:小白也能10分鐘學(xué)會,代碼效率直接起飛!

    是基于Lua語言實現(xiàn)的協(xié)作式并發(fā)控制機制,專為嵌入式及物聯(lián)網(wǎng)場景設(shè)計, 其核心特點是通過用戶態(tài)任務(wù)調(diào)度,在單線程模擬多任務(wù)執(zhí)行。 LuatOS協(xié)
    的頭像 發(fā)表于 04-10 15:23 ?155次閱讀
    LuatOS協(xié)<b class='flag-5'>程</b>深度解析:小白也能10分鐘學(xué)會,代碼效率直接起飛!

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

    各位程序員朋友(和假裝懂技術(shù)的同事):如果你在面試時被問到:\"請用奶茶店類比進(jìn)程線程和協(xié)\",而你回答:\"進(jìn)程是老板,
    發(fā)表于 03-26 09:27

    詳解RTOS的Hook函數(shù)

    Hook函數(shù)是RTOS的一個關(guān)鍵特性,通過該函數(shù),用戶可以增強對任務(wù)管理的控制,定義系統(tǒng)行為。
    的頭像 發(fā)表于 03-24 16:14 ?315次閱讀

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

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

    RTOS的本地存儲指針使用

    本地存儲指針是RTOS的一個重要特性,增強了任務(wù)管理和數(shù)據(jù)處理能力。在RTOS上下文中,本地存儲是指存儲在本地的特定任務(wù)或?qū)ο蟮臄?shù)據(jù)。通常
    的頭像 發(fā)表于 02-28 16:33 ?873次閱讀
    <b class='flag-5'>RTOS</b><b class='flag-5'>中</b>的本地存儲指針使用

    EE-303:將VisualDSP線程安全庫與第三方RTOS配合使用

    電子發(fā)燒友網(wǎng)站提供《EE-303:將VisualDSP線程安全庫與第三方RTOS配合使用.pdf》資料免費下載
    發(fā)表于 01-07 14:09 ?0次下載
    EE-303:將VisualDSP<b class='flag-5'>線程</b>安全庫與第三方<b class='flag-5'>RTOS</b>配合使用

    使用任務(wù)通知提高RTOS應(yīng)用的效率

    在實時嵌入式系統(tǒng),性能和資源效率是決定設(shè)計成敗的關(guān)鍵因素。傳統(tǒng)的實時操作系統(tǒng)(RTOS)提供了如隊列、信號量和事件組機制,實現(xiàn)任務(wù)之間的同步和通信。FreeRTOS/SAFERTOS還提供一種方法可以使這些過程更快、更輕量化,
    的頭像 發(fā)表于 12-27 14:54 ?648次閱讀

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

    是指在同一個進(jìn)程運行多個線程,每個線程可以獨立執(zhí)行任務(wù)線程共享
    的頭像 發(fā)表于 11-12 14:16 ?938次閱讀

    一文搞懂Linux進(jìn)程的睡眠和喚醒

    指定的微秒數(shù)。 nanosleep(): 使進(jìn)程暫停指定的納秒數(shù)。 Tips:睡眠機制幫助節(jié)省CPU資源,尤其是在I/O密集型任務(wù);在可中斷睡眠狀態(tài)下,進(jìn)程在收到信號時會被喚醒并處
    發(fā)表于 11-04 15:15

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

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

    rtthread是搶占式的rtos,那么線程的timeout參數(shù)具體的作用是什么呢?

    查閱相關(guān)說明,rtthread是搶占式的rtos,那么線程的timeout參數(shù)具體的作用是什么呢, 假如線程A,B的優(yōu)先級分別是1和2,timeout是10ms。當(dāng)線程B 在運行
    發(fā)表于 09-27 08:39

    什么是實時操作系統(tǒng)(3)-在 RTOS 可以期待什么?

    RTOS使用各種機制來管理任務(wù)、事件和內(nèi)存,以確保嵌入式系統(tǒng)滿足時間約束。在本節(jié),您將了解構(gòu)建嵌入式應(yīng)用程序時需要考慮的RTOS功能,例如確定性、空間和時間分離、調(diào)度、內(nèi)存管理和
    的頭像 發(fā)表于 07-23 12:00 ?1410次閱讀
    什么是實時操作系統(tǒng)(3)-在 <b class='flag-5'>RTOS</b> <b class='flag-5'>中</b>可以期待什么?

    摩爾線程與清極智達(dá)建立戰(zhàn)略合作關(guān)系

    摩爾線程與清華系人工智能系統(tǒng)軟件公司清極智科技有限公司(簡稱:清極智)近日共同宣布,雙方正式建立戰(zhàn)略合作關(guān)系。此次合作旨在加速國產(chǎn)大規(guī)模GPU智算集群的產(chǎn)業(yè)化進(jìn)程,推動人工智能算力
    的頭像 發(fā)表于 07-16 17:16 ?1064次閱讀

    為什么RTOS SDK的Rom指針比非OS SDK少?

    我不使用 NON-OS SDK,因為我更喜歡 RTOS 版本。 令我驚訝的是,這些函數(shù)在 RTOS SDK 不存在。 有人可以告訴我RTO
    發(fā)表于 07-10 07:53
    主站蜘蛛池模板: 真人一级一级特黄高清毛片 | 国外免费一级 | 老师您的兔子好软水好多动漫视频 | 国产精品色婷婷在线观看 | 黄色国产精品 | 91大神精品 | 国产黄在线观看 | 欧美精品一区二区三区视频 | 国产成人一区二区在线不卡 | 网站免费黄 | 综综综综合网 | 婷婷六月综合 | 黄色插插插 | 一级毛片在线 | 亚洲人成电影院在线观看 | 琪琪午夜伦埋大全影院 | 欧美潘金莲一级风流片a级 欧美片欧美日韩国产综合片 | 全部免费特黄特色大片视频 | 日韩精品一级毛片 | 国产男人午夜视频在线观看 | 色妞综合 | 色成年激情久久综合 | 亚洲天堂2013 | 天堂网www在线资源网 | 久久国产美女免费观看精品 | 高清一区二区三区四区五区 | 免费又爽又黄1000禁片 | 日本在线不卡视频 | 亚洲欧美在线一区二区 | 717影院理伦午夜论八戒 | 国产做爰一区二区 | 国产色系视频在线观看免费 | 俺来也婷婷 | 亚洲伊人成人网 | 乱小说录目伦200篇将曲勒 | 香蕉久久影院 | 新版天堂中文在线8官网 | 夜间免费视频 | 2021精品国产综合久久 | 亚洲不卡视频在线 | 1000部啪啪未满十八勿入中国 |