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

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

3天內不再提示

總結進程、線程、進程池、同步、異步、并發(fā)、并行、串行

STM32嵌入式開發(fā) ? 來源:Shawn派大星 ? 2023-02-09 14:52 ? 次閱讀

進程、線程

什么是進程?

開發(fā)寫的代碼我們稱為程序,那么將開發(fā)的代碼運行起來。我們稱為進程。

明白點: 當我們運行一個程序,那么我們將運行的程序叫進程。

精簡重點

進程是申請一塊內存空間,將數據放到內存空間中去,是申請數據的過程是最小的資源管理單元

進程是線程的容器

程序與進程的區(qū)別

程序是數據和指令的集合, 是一個靜態(tài)的概念, 就是一堆代碼, 可以長時間的保存在系統(tǒng)中

進程是程序運行的過程, 是一個動態(tài)的概念, 進程存在著生命周期, 也就是說進程會隨著程序的終止而銷毀, 不會永久存在系統(tǒng)中

進程之間交互

進程之間通過 TCP/IP 端口實現

什么是線程

線程是操作系統(tǒng)能夠進行運算調度的最小單位。

它被包含在進程之中,是進程中的實際運作單位。

一條線程指的是進程中一個單一順序的控制流,一個進程中可以并發(fā)多個線程,每條線程并行執(zhí)行不同的任務。

精簡重點

是進程的一條流水線,只用來執(zhí)行程序,而不涉及到申請資源,是程序的實際執(zhí)行者最小的執(zhí)行單元

線程之間交互

多個線程共享同一塊內存,通過共享的內存空間來進行交互

進程與線程的關系

例子:

我們打開一個聊天軟件,這就是開啟了一個進程;當我們在軟件里面打開一些功能,比如空間, 掃一掃, 設置...,這些操作就是線程 所以可以說"進程"包含"線程","線程"是"進程"的子集

進程是線程的容器

工廠流水線例子:

fc954d02-a831-11ed-bfe3-dac502259ad0.png

fca5c1dc-a831-11ed-bfe3-dac502259ad0.png

進程:指在系統(tǒng)中正在運行的一個應用程序;程序一旦運行就是進程;進程——資源分配的最小單位。

線程:系統(tǒng)分配處理器時間資源的基本單元,或者說進程之內獨立執(zhí)行的一個單元執(zhí)行流。線程——程序執(zhí)行的最小單位。

進程要分配一大部分的內存,而線程只需要分配一部分棧就可以了.

一個程序至少有一個進程,一個進程至少有一個線程.

一個線程可以創(chuàng)建和撤銷另一個線程,同一個進程中的多個線程之間可以并發(fā)執(zhí)行.

并行、并發(fā)、串行

并發(fā): 多個任務看起來是同時進行, 這是一種假并行

單核下使用多道技術實現

fcc90db8-a831-11ed-bfe3-dac502259ad0.png

并行: 多個任務同時進行

并行必須有多核才能實現,否則只能實現并發(fā)(偽并行)。

fce11fd4-a831-11ed-bfe3-dac502259ad0.png

串行: 一個程序完完整整的運行完,再運行下一個進程

fcfce14c-a831-11ed-bfe3-dac502259ad0.png

任務運行的三種狀態(tài)

進程在運行的過程中不斷地改變其運行狀態(tài)。 通常一個運行的進程必須具有三種狀態(tài):就緒態(tài),運行態(tài),阻塞態(tài)。

就緒態(tài) (Ready)

當進程已分配到除CPU以外的所有必要的資源后,只要再獲得CPU, 便可執(zhí)行程序, 進程這時的狀態(tài)就稱為就緒態(tài),

在一個系統(tǒng)中處于就緒態(tài)的進程可能有多個, 通常將他們排成一個隊列, 這就叫就緒隊列

運行態(tài) (Running)

當進程已經獲得CPU操作權限, 其程序正在運行, 著就叫做運行態(tài)

在單核操作系統(tǒng)中, 只有一個進程處于運行態(tài), 多核操作系統(tǒng)有多個進程處于運行態(tài)

阻塞態(tài) (Blocked)(sleep)

正在執(zhí)行的進程, 由于等待某個事件而無法執(zhí)行時, 便被操作系統(tǒng)剝奪了cpu的操作時間, 這是就是阻塞態(tài)

引起阻塞的原因多種, 例如: 等待I/O操作, 更高優(yōu)先級的任務搶走了CPU權限等.

進程三種狀態(tài) 間的轉換

一個進程在運行期間,會不斷地在一種狀態(tài)切換到另一只種狀態(tài) 他可以是多次處于就緒態(tài)和運行態(tài),也可以多次處于阻塞態(tài),下圖是三種狀態(tài)的轉換圖

fd2186dc-a831-11ed-bfe3-dac502259ad0.png

就緒態(tài)??運行態(tài)

處于就緒態(tài)的進程,當進程調度程序為之分配了CPU的時間片后,該進程就會由就緒態(tài)轉變成運行態(tài)

運行態(tài)??就緒態(tài)

處于運行態(tài)的進程在運行過程中,因為分配的時間片用完了,于是失去了CPU的使用權限,運行態(tài)就會重新轉為就緒態(tài)

運行態(tài)??阻塞態(tài)

正在運行的進程由于遇到I/O操作或被更高優(yōu)先級的任務搶走CPU使用權限而無法繼續(xù)執(zhí)行,便從運行態(tài)轉為阻塞態(tài)

阻塞態(tài)??就緒態(tài)

處于阻塞態(tài)的進程,若其等待的事情已經處理完畢,于是進程從阻塞態(tài)轉為就緒態(tài)

任務提交的兩種方式

同步

同步是指發(fā)送方發(fā)送數據后, 等接收方發(fā)回響應后才發(fā)下一個數據報的通訊方式

同步是指兩個程序的運行是相關的, 其中一個線程在阻塞需要等待狀態(tài), 那另一個線程才運行

異步

異步是指發(fā)送方發(fā)出數據后, 不等接收方發(fā)回響應, 接著就發(fā)下個數據報的通訊方式

異步是指兩個線程毫無相關, 自己運行自己的

例子

同步:

你叫我去吃飯,我聽到了就立即和你去吃飯,如果沒有聽到,你就不停的叫,直到我告訴你聽到了,才一起去吃飯 打電話好比同步,兩邊是同時進行不能再打給另一個人

異步:

你叫我去吃飯,然后自己去吃飯了,我得到消息后可能立即走,也可能過會兒走 發(fā)消息好比異步,和一個人發(fā)完消息就可能和另一個人發(fā)消息

進程池

什么是進程池?

進程池是資源進程,管理進程組成的技術的應用.

為什么要有進程池?

忙時會有成千上萬的任務需要被執(zhí)行,閑時可能只有零星任務。 那么在成千上萬個任務需要被執(zhí)行的時候,我們就需要去創(chuàng)建成千上萬個進程么? 首先,創(chuàng)建進程需要消耗時間,銷毀進程也需要消耗時間。 第二即便開啟了成千上萬的進程,操作系統(tǒng)也不能讓他們同時執(zhí)行,這樣反而會影響程序的效率。 因此我們不能無限制的根據任務去開啟或者結束進程。那么我們要怎么做呢?

進程池的概念

定義一個池子,在里面放上固定數量的進程,有需求來了,就拿一個池中的進程來處理任務

等到處理完畢,進程并不關閉,而是將進程再放回進程池中繼續(xù)等待任務

如果有很多任務需要執(zhí)行,池中的進程數量不夠,任務就要等待之前的進程執(zhí)行任務完畢歸來,拿到空閑進程才能繼續(xù)執(zhí)行。

也就是說,進池中進程的數量是固定的,那么同一時間最多有固定數量的進程在運行

這樣不會增加操作系統(tǒng)的調度難度,還節(jié)省了開關進程的時間,也一定程度上能夠實現并發(fā)效果。

資源進程

預先創(chuàng)建好的空閑進程,管理進程(好比池子)會把工作分發(fā)到空閑進程來處理。

管理進程

管理進程負責創(chuàng)建資源進程,把工作交給空閑資源進程處理,回收已經處理完工作的資源進程。

資源進程與管理進程的交互

管理進程如何有效的管理資源進程,分配任務給資源進程? 通過IPC,信號,信號量,消息隊列,管道等進行交互。

審核編輯 :李倩

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

    關注

    0

    文章

    237

    瀏覽量

    33772
  • 線程
    +關注

    關注

    0

    文章

    504

    瀏覽量

    19636
  • 進程
    +關注

    關注

    0

    文章

    201

    瀏覽量

    13941

原文標題:總結進程、線程、進程池、同步、異步、并發(fā)、并行、串行

文章出處:【微信號:c-stm32,微信公眾號:STM32嵌入式開發(fā)】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    進程線程的區(qū)別

    是資源分配和擁有的單位,同一個進程內的線程共享進程的資源(3)線程是處理器調度的基本單位,但進程不是.4)二者均可
    發(fā)表于 12-12 09:28

    進程線程區(qū)別

    工人都可以進出的。這象征一個進程的內存空間是共享的,每個線程都可以使用這些共享內存。進程線程是操作系統(tǒng)的兩種不同軟件技術,目的是實現宏觀上的并行
    發(fā)表于 11-30 14:06

    線程進程、程序的區(qū)別

    分配資源的基本單位,而把線程作為獨立運行和獨立調度的基本單位。由于線程進程更小,基本上不擁有系統(tǒng)資源,故對它的調度所付出的開銷就會小得多,能更高效的提高系統(tǒng)內多個程序間并發(fā)執(zhí)行的程度
    發(fā)表于 03-23 13:09

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

    發(fā)生了變化:它只是資源分配的單位,而不再是調度運行的單位 。在微內核系統(tǒng)中,真正調度運行的基本單位是線程。因此,實現并發(fā)功能的單位是線程線程概念   
    發(fā)表于 07-04 00:18

    Linux系統(tǒng)進程的知識總結

    對象(CMutex)、信號量對象(CS emaphore)和事件對象(CEvent)。在這些對象中,臨界區(qū)對象使用起來最簡單,它的缺點是只能同步同一個進程中的線程。另外,還有一種基本的方法,本文稱為
    發(fā)表于 09-06 12:00

    進程互斥、同步概念

    進程同步與通信,進程線程同步的區(qū)別,進程線程
    發(fā)表于 06-05 06:24

    Java進程線程

    Windows等操作系統(tǒng)均支持多線程進程并發(fā)處理機制。操作系統(tǒng)支持多線程,使多個程序能夠并發(fā)執(zhí)行,以改善資源使用率和提高系統(tǒng)效率;操作系統(tǒng)
    發(fā)表于 07-31 15:10

    線程,進程和程序有什么區(qū)別

    我對于線程,進程的概念一直都是比較模糊,最近整理了一下。總結起來就是,線程進程的一部分,進程
    發(fā)表于 08-05 08:17

    如何使用多線程異步操作等并發(fā)設計方法來最大化程序的性能

    的DMA操作?! ?b class='flag-5'>線程的本質  線程不是一個計算機硬件的功能,而是操作系統(tǒng)提供的一種邏輯功能,線程本質上是進程中一段并發(fā)運行的代碼,所以
    發(fā)表于 08-23 16:31

    進程與多線程的基本概念

    (英語:thread,***譯為運行緒),操作系統(tǒng)技術中的術語,是操作系統(tǒng)能夠進行運算調度的最小單位。它被包涵在進程之中,一條線程指的是進程中一個單一順序的控制流,一個進程中可以
    發(fā)表于 04-02 14:49 ?739次閱讀

    進程線程定義

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

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

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

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

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

    mcu線程進程的區(qū)別是什么

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

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

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