日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當(dāng)前位置:首頁 > 嵌入式 > 嵌入式教程
[導(dǎo)讀]進程的概念首先是在20世紀(jì)60年代初期由MIT的Multics系統(tǒng)和IBM的TSS/360系統(tǒng)引入的。在40多年的發(fā)展中,人們對進程有過各種各樣的定義?,F(xiàn)列舉較為著名的幾種。

7.1Linux進程概述7.1.1進程的基本概念1.進程的定義

進程的概念首先是在20世紀(jì)60年代初期由MIT的Multics系統(tǒng)和IBM的TSS/360系統(tǒng)引入的。在40多年的發(fā)展中,人們對進程有過各種各樣的定義?,F(xiàn)列舉較為著名的幾種。

(1)進程是一個獨立的可調(diào)度的活動(E.Cohen,D.Jofferson)。

(2)進程是一個抽象實體,當(dāng)它執(zhí)行某個任務(wù)時,要分配和釋放各種資源(P.Denning)。

(3)進程是可以并行執(zhí)行的計算單位。(S.E.Madnick,J.T.Donovan)。

以上進程的概念都不相同,但其本質(zhì)是一樣的。它指出了進程是一個程序的一次執(zhí)行的過程,同時也是資源分配的最小單元。它和程序是有本質(zhì)區(qū)別的,程序是靜態(tài)的,它是一些保存在磁盤上的指令的有序集合,沒有任何執(zhí)行的概念;而進程是一個動態(tài)的概念,它是程序執(zhí)行的過程,包括了動態(tài)創(chuàng)建、調(diào)度和消亡的整個過程。它是程序執(zhí)行和資源管理的最小單位。因此,對系統(tǒng)而言,當(dāng)用戶在系統(tǒng)中鍵入命令執(zhí)行一個程序的時候,它將啟動一個進程。

2.進程控制塊

進程是Linux系統(tǒng)的基本調(diào)度和管理資源的單位,那么從系統(tǒng)的角度看如何描述并表示它的變化呢?在這里,是通過進程控制塊來描述的。進程控制塊包含了進程的描述信息、控制信息以及資源信息,它是進程的一個靜態(tài)描述。在Linux中,進程控制塊中的每一項都是一個task_struct結(jié)構(gòu),它是在include/linux/sched.h中定義的。

3.進程的標(biāo)識

在Linux中最主要的進程標(biāo)識有進程號(PID,ProcessIdenityNumber)和它的父進程號(PPID,parentprocessID)。其中PID惟一地標(biāo)識一個進程。PID和PPID都是非零的正整數(shù)。

在Linux中獲得當(dāng)前進程的PID和PPID的系統(tǒng)調(diào)用函數(shù)為getpid()和getppid(),通常程序獲得當(dāng)前進程的PID和PPID之后,可以將其寫入日志文件以做備份。getpid()和getppid()系統(tǒng)調(diào)用過程如下所示:

/*pid.c*/

#include<stdio.h>

#include<unistd.h>

#include<stdlib.h>

intmain()

{

/*獲得當(dāng)前進程的進程ID和其父進程ID*/

printf("ThePIDofthisprocessis%dn",getpid());

printf("ThePPIDofthisprocessis%dn",getppid());

}

使用arm-linux-gcc進行交叉編譯,再將其下載到目標(biāo)板上運行該程序,可以得到如下結(jié)果,該值在不同的系統(tǒng)上會有所不同:

$./pid

ThePIDofthisprocessis78

THePPIDofthisprocessis36

另外,進程標(biāo)識還有用戶和用戶組標(biāo)識、進程時間、資源利用情況等,這里就不做一一介紹,感興趣的讀者可以參見W.RichardStevens編著的《AdvancedProgrammingintheUNIXEnvironmen》。

4.進程運行的狀態(tài)

進程是程序的執(zhí)行過程,根據(jù)它的生命周期可以劃分成3種狀態(tài)。

n 執(zhí)行態(tài):該進程正在運行,即進程正在占用CPU。

n 就緒態(tài):進程已經(jīng)具備執(zhí)行的一切條件,正在等待分配CPU的處理時間片。

n 等待態(tài):進程不能使用CPU,若等待事件發(fā)生(等待的資源分配到)則可將其喚醒。

它們之間轉(zhuǎn)換的關(guān)系如圖7.1所示。

圖7.1進程3種狀態(tài)的轉(zhuǎn)化關(guān)系

7.1.2Linux下的進程結(jié)構(gòu)

Linux系統(tǒng)是一個多進程的系統(tǒng),它的進程之間具有并行性、互不干擾等特點。也就是說,每個進程都是一個獨立的運行單位,擁有各自的權(quán)利和責(zé)任。其中,各個進程都運行在獨立的虛擬地址空間,因此,即使一個進程發(fā)生異常,它也不會影響到系統(tǒng)中的其他進程。

Linux中的進程包含3個段,分別為“數(shù)據(jù)段”、“代碼段”和“堆棧段”。

n “數(shù)據(jù)段”存放的是全局變量、常數(shù)以及動態(tài)數(shù)據(jù)分配的數(shù)據(jù)空間,根據(jù)存放的數(shù)據(jù),數(shù)據(jù)段又可以分成普通數(shù)據(jù)段(包括可讀可寫/只讀數(shù)據(jù)段,存放靜態(tài)初始化的全局變量或常量)、BSS數(shù)據(jù)段(存放未初始化的全局變量)以及堆(存放動態(tài)分配的數(shù)據(jù))。

n “代碼段”存放的是程序代碼的數(shù)據(jù)。

n “堆棧段”存放的是子程序的返回地址、子程序的參數(shù)以及程序的局部變量等。如圖7.2所示。、

圖7.2Linux中進程結(jié)構(gòu)示意圖

7.1.3Linux下進程的模式和類型

在Linux系統(tǒng)中,進程的執(zhí)行模式劃分為用戶模式和內(nèi)核模式。如果當(dāng)前運行的是用戶程序、應(yīng)用程序或者內(nèi)核之外的系統(tǒng)程序,那么對應(yīng)進程就在用戶模式下運行;如果在用戶程序執(zhí)行過程中出現(xiàn)系統(tǒng)調(diào)用或者發(fā)生中斷事件,那么就要運行操作系統(tǒng)(即核心)程序,進程模式就變成內(nèi)核模式。在內(nèi)核模式下運行的進程可以執(zhí)行機器的特權(quán)指令,而且此時該進程的運行不受用戶的干擾,即使是root用戶也不能干擾內(nèi)核模式下進程的運行。

用戶進程既可以在用戶模式下運行,也可以在內(nèi)核模式下運行,如圖7.3所示。

圖7.3用戶進程的兩種運行模式

7.1.4Linux下的進程管理

Linux下的進程管理包括啟動進程和調(diào)度進程,下面就分別對這兩方面進行簡要講解。

1.啟動進程

Linux下啟動一個進程有兩種主要途徑:手工啟動和調(diào)度啟動。手工啟動是由用戶輸入命令直接啟動進程,而調(diào)度啟動是指系統(tǒng)根據(jù)用戶的設(shè)置自行啟動進程。

(1)手工啟動。

手工啟動進程又可分為前臺啟動和后臺啟動。

n 前臺啟動是手工啟動一個進程的最常用方式。一般地,當(dāng)用戶鍵入一個命令如“ls-l”時,就已經(jīng)啟動了一個進程,并且是一個前臺的進程。

n 后臺啟動往往是在該進程非常耗時,且用戶也不急著需要結(jié)果的時候啟動的。比如用戶要啟動一個需要長時間運行的格式化文本文件的進程。為了不使整個shell在格式化過程中都處于“癱瘓”狀態(tài),從后臺啟動這個進程是明智的選擇。

(2)調(diào)度啟動。

有時,系統(tǒng)需要進行一些比較費時而且占用資源的維護工作,并且這些工作適合在深夜無人值守的時候進行,這時用戶就可以事先進行調(diào)度安排,指定任務(wù)運行的時間或者場合,到時候系統(tǒng)就會自動完成這一切工作。

使用調(diào)度啟動進程有幾個常用的命令,如at命令在指定時刻執(zhí)行相關(guān)進程,cron命令可以自動周期性地執(zhí)行相關(guān)進程,在需要使用時讀者可以查看相關(guān)幫助手冊。

2.調(diào)度進程

調(diào)度進程包括對進程的中斷操作、改變優(yōu)先級、查看進程狀態(tài)等,在Linux下可以使用相關(guān)的系統(tǒng)命令實現(xiàn)其操作,在表7.1中列出了Linux中常見的調(diào)用進程的系統(tǒng)命令,讀者在需要的時候可以自行查找其用法。

表7.1 Linux中進程調(diào)度常見命令

選項

參數(shù)含義

ps

查看系統(tǒng)中的進程

top

動態(tài)顯示系統(tǒng)中的進程

nice

按用戶指定的優(yōu)先級運行

renice

改變正在運行進程的優(yōu)先級

kill

向進程發(fā)送信號(包括后臺進程)

crontab

用于安裝、刪除或者列出用于驅(qū)動cron后臺進程的任務(wù)。

bg

將掛起的進程放到后臺執(zhí)行

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

CPU親和度通過限制進程或線程可以運行的CPU核心集合,使得它們只能在指定的CPU核心上執(zhí)行。這可以減少CPU緩存的失效次數(shù),提高緩存命中率,從而提升系統(tǒng)性能。

關(guān)鍵字: Linux 嵌入式

在Linux系統(tǒng)性能優(yōu)化中,內(nèi)存管理與網(wǎng)絡(luò)連接處理是兩大核心領(lǐng)域。vm.swappiness與net.core.somaxconn作為關(guān)鍵內(nèi)核參數(shù),直接影響系統(tǒng)在高負載場景下的穩(wěn)定性與響應(yīng)速度。本文通過實戰(zhàn)案例解析這兩個...

關(guān)鍵字: Linux 內(nèi)存管理

對于LLM,我使用b谷歌Gemini的免費層,所以唯一的成本是n8n托管。在使用了n8n Cloud的免費積分后,我決定將其托管在Railway上(5美元/月)。然而,由于n8n是開源的,您可以在自己的服務(wù)器上托管它,而...

關(guān)鍵字: 人工智能 n8n Linux

在Linux系統(tǒng)管理中,權(quán)限控制是安全運維的核心。本文通過解析/etc/sudoers文件配置與組策略的深度應(yīng)用,結(jié)合某金融企業(yè)生產(chǎn)環(huán)境案例(成功攔截98.7%的非法提權(quán)嘗試),揭示精細化權(quán)限管理的關(guān)鍵技術(shù)點,包括命令別...

關(guān)鍵字: Linux 用戶權(quán)限 sudoers文件

Linux內(nèi)核中的信號量(Semaphore)是一種用于資源管理的同步原語,它允許多個進程或線程對共享資源進行訪問控制。信號量的主要作用是限制對共享資源的并發(fā)訪問數(shù)量,從而防止系統(tǒng)過載和數(shù)據(jù)不一致的問題。

關(guān)鍵字: Linux 嵌入式

在云計算與容器化技術(shù)蓬勃發(fā)展的今天,Linux網(wǎng)絡(luò)命名空間(Network Namespace)已成為構(gòu)建輕量級虛擬網(wǎng)絡(luò)的核心組件。某頭部互聯(lián)網(wǎng)企業(yè)通過命名空間技術(shù)將測試環(huán)境資源消耗降低75%,故障隔離效率提升90%。本...

關(guān)鍵字: Linux 云計算

在Linux內(nèi)核4.18+和主流發(fā)行版(RHEL 8/Ubuntu 20.04+)全面轉(zhuǎn)向nftables的背景下,某電商平臺通過遷移將防火墻規(guī)則處理效率提升40%,延遲降低65%。本文基于真實生產(chǎn)環(huán)境案例,詳解從ipt...

關(guān)鍵字: nftables Linux

在Linux設(shè)備驅(qū)動開發(fā)中,等待隊列(Wait Queue)是實現(xiàn)進程睡眠與喚醒的核心機制,它允許進程在資源不可用時主動放棄CPU,進入可中斷睡眠狀態(tài),待資源就緒后再被喚醒。本文通過C語言模型解析等待隊列的實現(xiàn)原理,結(jié)合...

關(guān)鍵字: 驅(qū)動開發(fā) C語言 Linux

在Unix/Linux進程間通信中,管道(pipe)因其簡單高效被廣泛使用,但默認的半雙工特性和無同步機制容易導(dǎo)致數(shù)據(jù)競爭。本文通過父子進程雙向通信案例,深入分析互斥鎖與狀態(tài)機在管道同步中的應(yīng)用,實現(xiàn)100%可靠的數(shù)據(jù)傳...

關(guān)鍵字: 管道通信 父子進程 Linux

RTOS :RTOS的核心優(yōu)勢在于其實時性。它采用搶占式調(diào)度策略,確保高優(yōu)先級任務(wù)能夠立即獲得CPU資源,從而在最短時間內(nèi)完成處理。RTOS的實時性是通過嚴(yán)格的時間管理和任務(wù)調(diào)度算法實現(xiàn)的,能夠滿足對時間敏感性要求極高的...

關(guān)鍵字: Linux RTOS
關(guān)閉