91欧美超碰AV自拍|国产成年人性爱视频免费看|亚洲 日韩 欧美一厂二区入|人人看人人爽人人操aV|丝袜美腿视频一区二区在线看|人人操人人爽人人爱|婷婷五月天超碰|97色色欧美亚州A√|另类A√无码精品一级av|欧美特级日韩特级

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

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

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

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

strongerHuang ? 來(lái)源:CSDN技術(shù)社區(qū) ? 作者:最后一個(gè)bug ? 2021-04-19 10:06 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

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

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

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

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

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

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

1)并發(fā)與并行

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

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

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

2) 進(jìn) 程

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

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

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

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

3) 線 程

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

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

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

同時(shí)現(xiàn)在目前大部分OS其線程的管理、調(diào)度和并發(fā)都是通過內(nèi)核了完成的,這樣就會(huì)存在較多系統(tǒng)調(diào)用以及從用戶態(tài)到內(nèi)核態(tài)的切換,都會(huì)消耗一些時(shí)間,為了更進(jìn)一步減少開銷,直接在用戶態(tài)實(shí)現(xiàn)更好的并發(fā)就出現(xiàn)了協(xié)程概念。

4) 協(xié) 程

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

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

協(xié)程的特點(diǎn):

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

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

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

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

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

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

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

4、最后小節(jié)

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

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

    關(guān)注

    25

    文章

    866

    瀏覽量

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

    關(guān)注

    0

    文章

    509

    瀏覽量

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

    關(guān)注

    0

    文章

    211

    瀏覽量

    14536

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

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

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

掃碼添加小助手

加入工程師交流群

    評(píng)論

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

    【瑞薩FPB-RA6E2試用】【瑞薩FPB-RA6E2】RTOS(Real-Time Operating System,實(shí)時(shí)操作系統(tǒng))《線程》個(gè)人理解及項(xiàng)目實(shí)現(xiàn)

    System,實(shí)時(shí)操作系統(tǒng))線程含義 在 RTOS(Real-Time Operating System,實(shí)時(shí)操作系統(tǒng)) 線程(Thread) 是
    發(fā)表于 01-14 11:50

    使用RTOS時(shí)需要注意的幾點(diǎn)內(nèi)容分享

    RTOS產(chǎn)品代碼少和速度快,現(xiàn)在RTOS還提升了一致性。RTOS除能很快完成任務(wù)外,還能保證很好地完成任務(wù)。 在許多應(yīng)用
    發(fā)表于 12-23 06:34

    解析Linux的進(jìn)程、線程和協(xié)

    允許在單個(gè)線程內(nèi)實(shí)現(xiàn)多個(gè)協(xié)的并發(fā)執(zhí)行。協(xié)在執(zhí)行過程可以主動(dòng)掛起和恢復(fù),這使得編寫高效的異步代碼變得更加容易。協(xié)通常用于處理I/O密集
    發(fā)表于 12-22 11:00

    嵌入式基礎(chǔ)知識(shí)-系統(tǒng)調(diào)度

    系統(tǒng)調(diào)度是操作系統(tǒng)重要功能,在嵌入式開發(fā),也要了解系統(tǒng)調(diào)度的基本原理。對(duì)于嵌入式Linux開發(fā),一般使用多線程和多進(jìn)程開發(fā),對(duì)于運(yùn)行RTOS的嵌入式系統(tǒng),一般使用多任務(wù)開發(fā)。這些
    發(fā)表于 12-16 08:15

    選擇RTOS的要點(diǎn)

    選擇RTOS。大多數(shù)RTOS產(chǎn)品代碼少和速度快,現(xiàn)在RTOS還提升了一致性。RTOS除能很快完成任務(wù)外,還能保證很好地完成
    發(fā)表于 12-12 08:00

    FreeRTOS任務(wù)和協(xié)的區(qū)別是什么

    1.堆棧 協(xié)是沒有堆棧分配的,是所有創(chuàng)建的協(xié)共同使用一個(gè)堆??臻g,這相比于任務(wù)來(lái)說(shuō),減少了RAM的使用空間。 2. 調(diào)度和優(yōu)先級(jí) 協(xié)使用協(xié)同調(diào)度,但是可以包含在使用的搶占優(yōu)先級(jí)之
    發(fā)表于 12-08 08:18

    線程的系統(tǒng)

    線程系統(tǒng)的事件響應(yīng)也是在中斷完成的,但事件的處理是在線程完成的。在多線程系統(tǒng),
    發(fā)表于 12-08 07:55

    FreeRTOS 空閑任務(wù)

    幾乎所有的小型 RTOS 中都會(huì)有一個(gè)空閑任務(wù),空閑任務(wù)屬于系統(tǒng)任務(wù),是必須要執(zhí)行的,用戶程序不能將其關(guān)閉。不光小型系統(tǒng)中有空閑
    發(fā)表于 12-04 07:35

    Linux多線程對(duì)比單線程的優(yōu)勢(shì)

    在Linux系統(tǒng),線程是操作系統(tǒng)能夠進(jìn)行運(yùn)算調(diào)度的最小單位。線程被包含在進(jìn)程之中,是進(jìn)程的實(shí)
    發(fā)表于 12-01 06:11

    RTOS 必學(xué)概念:任務(wù)、信號(hào)量、隊(duì)列一次搞懂

    如果你剛接觸RTOS(實(shí)時(shí)操作系統(tǒng)),很可能會(huì)有這樣的困惑:“RTOS和裸機(jī)程序到底有什么區(qū)別?”“任務(wù)線程嗎?為什么要分任務(wù)?”“信號(hào)量
    的頭像 發(fā)表于 11-17 10:53 ?466次閱讀
    <b class='flag-5'>RTOS</b> 必學(xué)概念:<b class='flag-5'>任務(wù)</b>、信號(hào)量、隊(duì)列一次搞懂

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

    線程進(jìn)程 一個(gè)進(jìn)程指的是一個(gè)正在執(zhí)行的應(yīng)用程序,而線程的功能是執(zhí)行應(yīng)用程序的某個(gè)具體任務(wù)。
    發(fā)表于 09-01 21:31

    RTOS如何在FX3工作?

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

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

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

    詳解RTOS的Hook函數(shù)

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

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

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