資料介紹
引 言
在對(duì)實(shí)時(shí)采集更新的數(shù)據(jù)進(jìn)行處理時(shí),往往會(huì)遇到數(shù)據(jù)更新速度與數(shù)據(jù)處理的速度不匹配的問(wèn)題。這種情況下,會(huì)出現(xiàn)數(shù)據(jù)丟失而導(dǎo)致數(shù)據(jù)處理結(jié)果不準(zhǔn)確,甚至?xí)?lái)不可預(yù)測(cè)的后果,因此需要一種機(jī)制來(lái)協(xié)調(diào)數(shù)據(jù)更新與數(shù)據(jù)處理,從而保證數(shù)據(jù)的完整性和處理結(jié)果的準(zhǔn)確性。作為一個(gè)多任務(wù)、多用戶操作系統(tǒng),Linux支持多個(gè)進(jìn)程在系統(tǒng)中并發(fā)運(yùn)行,由于進(jìn)程本身的動(dòng)態(tài)特性,用來(lái)描述實(shí)時(shí)數(shù)據(jù)處理非常合適,因此,解決好Linux進(jìn)程間的同步與通信問(wèn)題就能解決實(shí)時(shí)數(shù)據(jù)處理的問(wèn)題。
在Linux環(huán)境下,進(jìn)程通常存在運(yùn)行(running)、阻塞(blocked)、就緒(ready)、終止(terminated)四種狀態(tài)。當(dāng)多個(gè)進(jìn)程并發(fā)執(zhí)行時(shí),往往會(huì)出現(xiàn)進(jìn)程間的競(jìng)態(tài)。我們希望進(jìn)程能協(xié)調(diào)彼此間的行為,使得一個(gè)進(jìn)程只有在其他的進(jìn)程執(zhí)行到一個(gè)特定的點(diǎn)時(shí)才會(huì)執(zhí)行一個(gè)動(dòng)作,即控制同步;同時(shí),當(dāng)并發(fā)進(jìn)程訪問(wèn)共享數(shù)據(jù)時(shí)不應(yīng)當(dāng)出現(xiàn)競(jìng)爭(zhēng)條件。這一點(diǎn)通過(guò)在訪問(wèn)共享數(shù)據(jù)時(shí)執(zhí)行互斥來(lái)確保,即數(shù)據(jù)訪問(wèn)同步。
實(shí)現(xiàn)同步的基本技術(shù)是阻塞一個(gè)進(jìn)程,直到一個(gè)特定條件滿足為止;實(shí)現(xiàn)數(shù)據(jù)訪問(wèn)同步是通過(guò)阻塞一個(gè)進(jìn)程直到另外的進(jìn)程完成訪問(wèn)共享數(shù)據(jù)。
1 有限長(zhǎng)度緩沖區(qū)的生產(chǎn)者一消費(fèi)者問(wèn)題模型
當(dāng)僅存在單個(gè)生產(chǎn)者和消費(fèi)者時(shí),生產(chǎn)進(jìn)程和消費(fèi)進(jìn)程所對(duì)應(yīng)的是同樣的數(shù)據(jù)結(jié)構(gòu),它們共享同一個(gè)數(shù)據(jù)空間。生產(chǎn)進(jìn)程和消費(fèi)進(jìn)程如何進(jìn)行相互協(xié)調(diào),使得消費(fèi)進(jìn)程每次使用的數(shù)據(jù)都是生產(chǎn)進(jìn)程新生產(chǎn)寫人的,又使生產(chǎn)進(jìn)程新寫入的數(shù)據(jù)不會(huì)覆蓋還未被消費(fèi)進(jìn)程讀出使用的數(shù)據(jù),是該問(wèn)題模型實(shí)現(xiàn)的關(guān)鍵問(wèn)題。
在生產(chǎn)者一消費(fèi)者問(wèn)題模型中,生產(chǎn)者進(jìn)程不斷生產(chǎn)產(chǎn)品并把它們放入緩沖區(qū),消費(fèi)者進(jìn)程不斷從緩沖區(qū)中取走產(chǎn)品進(jìn)行消費(fèi)。當(dāng)緩沖區(qū)中產(chǎn)品已經(jīng)放滿時(shí),表示生產(chǎn)速度高于消費(fèi)速度,出現(xiàn)了供過(guò)于求,此時(shí)生產(chǎn)者必須等待產(chǎn)品被消費(fèi);當(dāng)緩沖區(qū)為空時(shí),表示消費(fèi)速度高于生產(chǎn)速度,出現(xiàn)了供不應(yīng)求,此時(shí)消費(fèi)者進(jìn)程必須等待產(chǎn)品的生產(chǎn)。生產(chǎn)和消費(fèi)的進(jìn)程必須達(dá)到同步運(yùn)行,才能實(shí)現(xiàn)供需平衡。
處理讀寫同步的兩種常見的策略被稱為“強(qiáng)讀者同步(strong reader synchronization)”和“強(qiáng)寫者同步(strongwriter synchronization)”。在強(qiáng)讀者同步中,總是給讀者以優(yōu)先權(quán),只要寫者當(dāng)前沒有進(jìn)行寫操作,讀者就可以獲得訪問(wèn)權(quán);在強(qiáng)寫者同步中,寫者總是獲得優(yōu)先權(quán),只要強(qiáng)讀者當(dāng)前沒有進(jìn)行讀操作,寫者就可以獲得訪問(wèn)權(quán)。而生產(chǎn)者消費(fèi)者同步與單純的讀寫同步又有不同,消費(fèi)者可以通過(guò)訪問(wèn)資源對(duì)資源進(jìn)行刪除或銷毀。
一個(gè)有限長(zhǎng)度緩沖區(qū)的生產(chǎn)者消費(fèi)者問(wèn)題模型,是由若干生產(chǎn)者和消費(fèi)者進(jìn)程以及一個(gè)有限的緩沖池構(gòu)成的。每個(gè)緩沖區(qū)能夠存儲(chǔ)一個(gè)信息記錄,一個(gè)生產(chǎn)者一次生產(chǎn)一個(gè)信息記錄。產(chǎn)生一個(gè)記錄之后,等待單獨(dú)進(jìn)入一個(gè)空的緩沖區(qū)后將記錄寫入緩沖區(qū)。一個(gè)消費(fèi)者進(jìn)程一次消費(fèi)一個(gè)信息記錄。當(dāng)它需要消費(fèi)時(shí),它等待單獨(dú)進(jìn)入一個(gè)滿的緩沖區(qū)后將記錄讀出。
通過(guò)上面的描述可以得出,解決生產(chǎn)者一消費(fèi)者問(wèn)題模型的方案需要滿足以下幾個(gè)條件:
◇生產(chǎn)者不應(yīng)覆蓋一個(gè)滿的緩沖區(qū);
◇消費(fèi)者不應(yīng)使用一個(gè)空的緩沖區(qū);
◇生產(chǎn)者和消費(fèi)者應(yīng)按互斥方式訪問(wèn)數(shù)據(jù)緩沖區(qū);
◇數(shù)據(jù)必須按照先進(jìn)先出(FIFO)方式;
◇不能出現(xiàn)忙等待。
必須避免數(shù)據(jù)寫進(jìn)程不斷、反復(fù)地檢查緩沖區(qū)直到找到一個(gè)空緩沖區(qū)為止,而讀進(jìn)程也必須避免不斷檢查直到找到一個(gè)滿緩沖區(qū)為止。這相當(dāng)于系統(tǒng)內(nèi)部產(chǎn)生忙等待,是在僅使用臨界段(CS)算法實(shí)現(xiàn)進(jìn)程同步時(shí)難以避免的問(wèn)題。
針對(duì)問(wèn)題模型解決方案的限制條件,采用信號(hào)量方式解決實(shí)時(shí)更新數(shù)據(jù)處理的進(jìn)程同步問(wèn)題,即上述的生產(chǎn)者一消費(fèi)者問(wèn)題模型。
信號(hào)量是一個(gè)非負(fù)值的共享整數(shù)值,只能用于初始化和不可分操作。不可分操作是指在對(duì)一個(gè)數(shù)據(jù)D進(jìn)行操作時(shí)不能與任何其他對(duì)D的操作重疊的操作。定義操作P和V為不可分操作。P和V的不可分性意味著這些操作不能并發(fā)執(zhí)行,避免了對(duì)信號(hào)量的競(jìng)爭(zhēng)條件。定義P和V的操作語(yǔ)義為:

由上述定義的語(yǔ)義看,對(duì)一個(gè)信號(hào)量S的操作,P和V為改變S的值,或者掛起或喚醒一個(gè)對(duì)S進(jìn)行P操作的進(jìn)程。被掛起的進(jìn)程為阻塞狀態(tài),因而避免了忙等待問(wèn)題。一個(gè)二進(jìn)制的信號(hào)量只取0和1,用來(lái)實(shí)現(xiàn)互斥。
在P和V操作中,對(duì)進(jìn)程的阻塞和喚醒需要操作系統(tǒng)的進(jìn)程管理組件的參與,因此信號(hào)量會(huì)被操作系統(tǒng)實(shí)現(xiàn)而不是應(yīng)用程序?qū)崿F(xiàn)。
在對(duì)實(shí)時(shí)采集更新的數(shù)據(jù)進(jìn)行處理時(shí),往往會(huì)遇到數(shù)據(jù)更新速度與數(shù)據(jù)處理的速度不匹配的問(wèn)題。這種情況下,會(huì)出現(xiàn)數(shù)據(jù)丟失而導(dǎo)致數(shù)據(jù)處理結(jié)果不準(zhǔn)確,甚至?xí)?lái)不可預(yù)測(cè)的后果,因此需要一種機(jī)制來(lái)協(xié)調(diào)數(shù)據(jù)更新與數(shù)據(jù)處理,從而保證數(shù)據(jù)的完整性和處理結(jié)果的準(zhǔn)確性。作為一個(gè)多任務(wù)、多用戶操作系統(tǒng),Linux支持多個(gè)進(jìn)程在系統(tǒng)中并發(fā)運(yùn)行,由于進(jìn)程本身的動(dòng)態(tài)特性,用來(lái)描述實(shí)時(shí)數(shù)據(jù)處理非常合適,因此,解決好Linux進(jìn)程間的同步與通信問(wèn)題就能解決實(shí)時(shí)數(shù)據(jù)處理的問(wèn)題。
在Linux環(huán)境下,進(jìn)程通常存在運(yùn)行(running)、阻塞(blocked)、就緒(ready)、終止(terminated)四種狀態(tài)。當(dāng)多個(gè)進(jìn)程并發(fā)執(zhí)行時(shí),往往會(huì)出現(xiàn)進(jìn)程間的競(jìng)態(tài)。我們希望進(jìn)程能協(xié)調(diào)彼此間的行為,使得一個(gè)進(jìn)程只有在其他的進(jìn)程執(zhí)行到一個(gè)特定的點(diǎn)時(shí)才會(huì)執(zhí)行一個(gè)動(dòng)作,即控制同步;同時(shí),當(dāng)并發(fā)進(jìn)程訪問(wèn)共享數(shù)據(jù)時(shí)不應(yīng)當(dāng)出現(xiàn)競(jìng)爭(zhēng)條件。這一點(diǎn)通過(guò)在訪問(wèn)共享數(shù)據(jù)時(shí)執(zhí)行互斥來(lái)確保,即數(shù)據(jù)訪問(wèn)同步。
實(shí)現(xiàn)同步的基本技術(shù)是阻塞一個(gè)進(jìn)程,直到一個(gè)特定條件滿足為止;實(shí)現(xiàn)數(shù)據(jù)訪問(wèn)同步是通過(guò)阻塞一個(gè)進(jìn)程直到另外的進(jìn)程完成訪問(wèn)共享數(shù)據(jù)。
1 有限長(zhǎng)度緩沖區(qū)的生產(chǎn)者一消費(fèi)者問(wèn)題模型
當(dāng)僅存在單個(gè)生產(chǎn)者和消費(fèi)者時(shí),生產(chǎn)進(jìn)程和消費(fèi)進(jìn)程所對(duì)應(yīng)的是同樣的數(shù)據(jù)結(jié)構(gòu),它們共享同一個(gè)數(shù)據(jù)空間。生產(chǎn)進(jìn)程和消費(fèi)進(jìn)程如何進(jìn)行相互協(xié)調(diào),使得消費(fèi)進(jìn)程每次使用的數(shù)據(jù)都是生產(chǎn)進(jìn)程新生產(chǎn)寫人的,又使生產(chǎn)進(jìn)程新寫入的數(shù)據(jù)不會(huì)覆蓋還未被消費(fèi)進(jìn)程讀出使用的數(shù)據(jù),是該問(wèn)題模型實(shí)現(xiàn)的關(guān)鍵問(wèn)題。
在生產(chǎn)者一消費(fèi)者問(wèn)題模型中,生產(chǎn)者進(jìn)程不斷生產(chǎn)產(chǎn)品并把它們放入緩沖區(qū),消費(fèi)者進(jìn)程不斷從緩沖區(qū)中取走產(chǎn)品進(jìn)行消費(fèi)。當(dāng)緩沖區(qū)中產(chǎn)品已經(jīng)放滿時(shí),表示生產(chǎn)速度高于消費(fèi)速度,出現(xiàn)了供過(guò)于求,此時(shí)生產(chǎn)者必須等待產(chǎn)品被消費(fèi);當(dāng)緩沖區(qū)為空時(shí),表示消費(fèi)速度高于生產(chǎn)速度,出現(xiàn)了供不應(yīng)求,此時(shí)消費(fèi)者進(jìn)程必須等待產(chǎn)品的生產(chǎn)。生產(chǎn)和消費(fèi)的進(jìn)程必須達(dá)到同步運(yùn)行,才能實(shí)現(xiàn)供需平衡。
處理讀寫同步的兩種常見的策略被稱為“強(qiáng)讀者同步(strong reader synchronization)”和“強(qiáng)寫者同步(strongwriter synchronization)”。在強(qiáng)讀者同步中,總是給讀者以優(yōu)先權(quán),只要寫者當(dāng)前沒有進(jìn)行寫操作,讀者就可以獲得訪問(wèn)權(quán);在強(qiáng)寫者同步中,寫者總是獲得優(yōu)先權(quán),只要強(qiáng)讀者當(dāng)前沒有進(jìn)行讀操作,寫者就可以獲得訪問(wèn)權(quán)。而生產(chǎn)者消費(fèi)者同步與單純的讀寫同步又有不同,消費(fèi)者可以通過(guò)訪問(wèn)資源對(duì)資源進(jìn)行刪除或銷毀。
一個(gè)有限長(zhǎng)度緩沖區(qū)的生產(chǎn)者消費(fèi)者問(wèn)題模型,是由若干生產(chǎn)者和消費(fèi)者進(jìn)程以及一個(gè)有限的緩沖池構(gòu)成的。每個(gè)緩沖區(qū)能夠存儲(chǔ)一個(gè)信息記錄,一個(gè)生產(chǎn)者一次生產(chǎn)一個(gè)信息記錄。產(chǎn)生一個(gè)記錄之后,等待單獨(dú)進(jìn)入一個(gè)空的緩沖區(qū)后將記錄寫入緩沖區(qū)。一個(gè)消費(fèi)者進(jìn)程一次消費(fèi)一個(gè)信息記錄。當(dāng)它需要消費(fèi)時(shí),它等待單獨(dú)進(jìn)入一個(gè)滿的緩沖區(qū)后將記錄讀出。
通過(guò)上面的描述可以得出,解決生產(chǎn)者一消費(fèi)者問(wèn)題模型的方案需要滿足以下幾個(gè)條件:
◇生產(chǎn)者不應(yīng)覆蓋一個(gè)滿的緩沖區(qū);
◇消費(fèi)者不應(yīng)使用一個(gè)空的緩沖區(qū);
◇生產(chǎn)者和消費(fèi)者應(yīng)按互斥方式訪問(wèn)數(shù)據(jù)緩沖區(qū);
◇數(shù)據(jù)必須按照先進(jìn)先出(FIFO)方式;
◇不能出現(xiàn)忙等待。
必須避免數(shù)據(jù)寫進(jìn)程不斷、反復(fù)地檢查緩沖區(qū)直到找到一個(gè)空緩沖區(qū)為止,而讀進(jìn)程也必須避免不斷檢查直到找到一個(gè)滿緩沖區(qū)為止。這相當(dāng)于系統(tǒng)內(nèi)部產(chǎn)生忙等待,是在僅使用臨界段(CS)算法實(shí)現(xiàn)進(jìn)程同步時(shí)難以避免的問(wèn)題。
針對(duì)問(wèn)題模型解決方案的限制條件,采用信號(hào)量方式解決實(shí)時(shí)更新數(shù)據(jù)處理的進(jìn)程同步問(wèn)題,即上述的生產(chǎn)者一消費(fèi)者問(wèn)題模型。
信號(hào)量是一個(gè)非負(fù)值的共享整數(shù)值,只能用于初始化和不可分操作。不可分操作是指在對(duì)一個(gè)數(shù)據(jù)D進(jìn)行操作時(shí)不能與任何其他對(duì)D的操作重疊的操作。定義操作P和V為不可分操作。P和V的不可分性意味著這些操作不能并發(fā)執(zhí)行,避免了對(duì)信號(hào)量的競(jìng)爭(zhēng)條件。定義P和V的操作語(yǔ)義為:

由上述定義的語(yǔ)義看,對(duì)一個(gè)信號(hào)量S的操作,P和V為改變S的值,或者掛起或喚醒一個(gè)對(duì)S進(jìn)行P操作的進(jìn)程。被掛起的進(jìn)程為阻塞狀態(tài),因而避免了忙等待問(wèn)題。一個(gè)二進(jìn)制的信號(hào)量只取0和1,用來(lái)實(shí)現(xiàn)互斥。
在P和V操作中,對(duì)進(jìn)程的阻塞和喚醒需要操作系統(tǒng)的進(jìn)程管理組件的參與,因此信號(hào)量會(huì)被操作系統(tǒng)實(shí)現(xiàn)而不是應(yīng)用程序?qū)崿F(xiàn)。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 永磁同步電機(jī)控制解析合集 84次下載
- Linux用戶態(tài)開發(fā)驅(qū)動(dòng)教程及基礎(chǔ)知識(shí) 7次下載
- Linux內(nèi)核進(jìn)程調(diào)度schedule深入理解的詳細(xì)資料說(shuō)明 5次下載
- 關(guān)于進(jìn)程與線程的解析PDF文件資料
- Linux教程之進(jìn)程的概念和進(jìn)程管理命令的使用 2次下載
- linux進(jìn)程的深入理解 2次下載
- Linux系統(tǒng)管道和有名管道的通信機(jī)制解析 0次下載
- Linux進(jìn)程調(diào)度的原理解析 1次下載
- 進(jìn)程間通信之Linux下進(jìn)程間通信概述 0次下載
- Linux守護(hù)進(jìn)程詳解 0次下載
- Linux進(jìn)程控制編程 0次下載
- Linux源碼分析系列的進(jìn)程 32次下載
- LINUX系統(tǒng)下多線程與多進(jìn)程性能分析
- Linux 2.6進(jìn)程調(diào)度
- Linux進(jìn)程管理 0次下載
- Linux系統(tǒng)進(jìn)程管理入門指南 971次閱讀
- Linux用戶身份與進(jìn)程權(quán)限詳解 1.2k次閱讀
- 讀寫分離怎么保證數(shù)據(jù)同步 2.1k次閱讀
- Linux中進(jìn)程、線程和協(xié)程的基礎(chǔ)概念 1.5k次閱讀
- 淺談Linux kernel中的同步機(jī)制 1.5k次閱讀
- 如何在Linux使用ps/pstree/top命令查看進(jìn)程 2.4k次閱讀
- 三態(tài)模型/五態(tài)模型/七態(tài)模型說(shuō)明 Linux操作系統(tǒng)的進(jìn)程狀態(tài)轉(zhuǎn)換 6.1k次閱讀
- 一行代碼教你如何隱藏Linux進(jìn)程 2.5k次閱讀
- Linux:測(cè)試進(jìn)程占用的虛擬內(nèi)存大小 3.4k次閱讀
- 虛擬機(jī):linux 進(jìn)程的最大線程個(gè)數(shù) 3.2k次閱讀
- Linux進(jìn)程調(diào)度時(shí)機(jī)概念分析 3.3k次閱讀
- 嵌入式Linux中進(jìn)程調(diào)度怎樣來(lái)解析 883次閱讀
- Linux進(jìn)程管理:什么是進(jìn)程?進(jìn)程的生命周期 8.9k次閱讀
- 基于嵌入式操作系統(tǒng)Linux環(huán)境中的沒有競(jìng)爭(zhēng)態(tài)讀寫進(jìn)程同步設(shè)計(jì) 906次閱讀
- 基于Linux進(jìn)程管理的詳細(xì)剖析 4.2k次閱讀
下載排行
本周
- 1冷柜-電氣控制系統(tǒng)講解
- 13.68 MB | 4次下載 | 10 積分
- 2安川A1000變頻器中文版說(shuō)明書
- 20.16 MB | 3次下載 | 3 積分
- 3直流電路的組成和基本定律
- 1.67 MB | 2次下載 | 免費(fèi)
- 4丹佛斯2800系列變頻器說(shuō)明書
- 8.00 MB | 1次下載 | 5 積分
- 5PC8011同步開關(guān)型降壓3.5A單節(jié)鋰電池充電管理電路技術(shù)手冊(cè)
- 0.74 MB | 1次下載 | 免費(fèi)
- 6ES7243E+ES8311音頻錄制與播放電路資料
- 0.06 MB | 1次下載 | 5 積分
- 7SDM02 激光測(cè)距模塊產(chǎn)品手冊(cè)
- 0.43 MB | 1次下載 | 免費(fèi)
- 8SDFM 激光測(cè)距模塊模組手冊(cè)
- 0.54 MB | 1次下載 | 免費(fèi)
本月
- 1CH341編程器軟件NeoProgrammer_2.2.0.10
- 20.47 MB | 170次下載 | 1 積分
- 22025智能家居傳感器市場(chǎng)分析及創(chuàng)新應(yīng)用
- 3.11 MB | 43次下載 | 免費(fèi)
- 3RV1126B系列開發(fā)板產(chǎn)品資料
- 4.19 MB | 18次下載 | 免費(fèi)
- 4CH341編程軟件下載
- 2.50 MB | 16次下載 | 5 積分
- 5全志系列-米爾基于T153核心板開發(fā)板 四核異構(gòu)、3路千兆網(wǎng),賦能多元化工業(yè)場(chǎng)景
- 3.05 MB | 12次下載 | 免費(fèi)
- 6【開源】60余套STM32單片機(jī)、嵌入式Linux、物聯(lián)網(wǎng)、人工智能項(xiàng)目案例及入門學(xué)習(xí)資源包
- 10.55 MB | 8次下載 | 免費(fèi)
- 7冷柜-電氣控制系統(tǒng)講解
- 13.68 MB | 4次下載 | 10 積分
- 8特斯拉MODEL S車載充電機(jī)主電路回路原理圖
- 0.81 MB | 4次下載 | 3 積分
總榜
- 1matlab軟件下載入口
- 未知 | 935137次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233094次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191448次下載 | 10 積分
- 5十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183356次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81604次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73824次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65991次下載 | 10 積分
電子發(fā)燒友App





創(chuàng)作
發(fā)文章
發(fā)帖
提問(wèn)
發(fā)資料
發(fā)視頻
上傳資料賺積分
評(píng)論