今天為大家講解講解OS中的線程、進程和協程的這幾個概念,同時一起看看RTOS中的任務到底屬于哪一種。
1、三者整體關系圖
很多小伙伴在學習OS的過程中會遇到各種程序形態,比如說進程、線程、協程、管程、纖程,oh my god!要是對他們不熟悉還真分辨不清楚,今天作者主要是把大家平時最常遇到的進程、線程和協程這三個概念講一講,其他形態作者后續再慢慢補充相關文章,下面我們簡單看一下windows里面的進程(Linux也是類似的),如下圖所示:
我們可以發現每行表示一個進程,同時一個進程包含多個線程,那么進程、線程和協程的關系到底是怎樣的呢?作者這里畫了個簡圖,供大家參考。
2、詳細分析一下
1)并發與并行
在講解進程之前我們先看看并發與并行的概念,并發字面上的意思就是一起發生,在乎的是一種感覺,對于單核CPU而言其對指令的處理都是順序執行,只是說類似于一種時間上分時交替處理,給用戶的一同發生的表象,這就是并發。
并行是指令同一時刻一起運行,這種方式一般在多處理器系統中發生。
2) 進 程
進程是一種程序的動態執行過程,進程對CPU并不是獨占連續執行的,OS管理著進程需要經常打斷當前的進程,并對多個進程進行監控調度等,那么在內核中就有一個結構體叫做進程控制塊PCB(學RTOS應該聽過任務控制塊TCB,后面會提到)-(Process Control Block),該結構體包含了該進程幾乎所有的信息和資源,那么OS也就是通過這個控制塊來獲得進程信息并管理進程。
進程的設計是為了讓各個應用程序能夠更好的進行隔離,比如在瀏覽網頁突然瀏覽器奔潰了這不會影響到我的音樂播放器,前面作者發布的OS對內存的管理可以了解到每個進程都會有自己獨立的內存空間,并且通過內存管理模塊MMU和頁表機制各個進程之間形成了隔離。
如果進行多進程的并發勢必需要保存當前進程現場信息,比如寄存器,堆棧,更新頁表,甚至還需要從外存(比如磁盤中)置換出進程進行運行,這樣對于CPU的開銷非常大,于是為了減少開銷便有了進程內的并發線程。
3) 線 程
進程的目的是隔離并發,可以說線程是實現的共享并發,所有的線程都是共用屬于進程的資源,線程是進程指令流的剝離,同樣線程有對應的結構體信息管理TCB類似于RTOS中的TCB。
由于線程資源共享,所以各個線程之間是會存在相互的影響,如果一個線程出現奔潰混亂,極大可能會影響到該進程中的其他線程;同時對于共享資源的讀寫也就會存在競爭問題,那么這樣就產生了一系列的共享資源的處理辦法,臨界區,互斥信號等等。
同時現在目前大部分OS其線程的管理、調度和并發都是通過內核了完成的,這樣就會存在較多系統調用以及從用戶態到內核態的切換,都會消耗一些時間,為了更進一步減少開銷,直接在用戶態實現更好的并發就出現了協程概念。
4) 協 程
之前的總覽關系圖我們也知道一個線程里面可以運行多個協程,其實函數調用就是一種狀態為初態的協程,A函數中調用B函數,可以認為是A任務切換到B任務來執行,然后執行完回到A任務,不過這樣調用的任務始終是從初始狀態開始,如果一個函數主動放棄CPU通過保存當前現場,比如寄存器值等,然后恢復到另外一個函數的寄存器狀態,便實現了任意狀態函數的并發執行,就實現了協程。好吧,解釋得有點繞,畫個圖理解理解:
協程的特點:
協程是用戶態執行的并發,相對線程開銷要小;
協程主動放棄占用,對相關資源不需要進行鎖處理;
非常適合IO密集型任務,比如非常經典的生產者與消費者的雙線程模式,如果用協程,生產出來以后立馬讓步給消費者進行處理,效率非常高。
3、RTOS任務屬于多線程
對于目前主流的RTOS,比如ucos,freeRTOS,RT-thread等等,都是屬于并發的線程,其實從RT-thread名字上看,其表示的就是實時的線程。
首先對于MCU上的資源每個任務都是共享的,可以認為是單進程多線程模型。
MCU一般沒有內存管理模塊MMU等等,這樣無法很好的實現進程的安全,如果用軟件實現,開銷太大,對于MCU沒有太多的必要,這也是為什么我們當個任務程序跑飛會導致整個程序無法運行的原因。
4、最后小節
可能部分小伙伴對于這幾個概念還有諸多疑惑,其并不是對這幾個概念不理解而是對OS的運行原理有些迷惑,所以大家對這部分感興趣也可以查找相關書籍進行系統的學習,加油!
編輯:lyn
-
RTOS
+關注
關注
22文章
811瀏覽量
119595 -
線程
+關注
關注
0文章
504瀏覽量
19675 -
進程
+關注
關注
0文章
203瀏覽量
13960
原文標題:RTOS中的任務是線程、進程、還是協程?
文章出處:【微信號:strongerHuang,微信公眾號:strongerHuang】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論