資料介紹
引 言
在對實時采集更新的數(shù)據(jù)進行處理時,往往會遇到數(shù)據(jù)更新速度與數(shù)據(jù)處理的速度不匹配的問題。這種情況下,會出現(xiàn)數(shù)據(jù)丟失而導(dǎo)致數(shù)據(jù)處理結(jié)果不準(zhǔn)確,甚至?xí)聿豢深A(yù)測的后果,因此需要一種機制來協(xié)調(diào)數(shù)據(jù)更新與數(shù)據(jù)處理,從而保證數(shù)據(jù)的完整性和處理結(jié)果的準(zhǔn)確性。作為一個多任務(wù)、多用戶操作系統(tǒng),Linux支持多個進程在系統(tǒng)中并發(fā)運行,由于進程本身的動態(tài)特性,用來描述實時數(shù)據(jù)處理非常合適,因此,解決好Linux進程間的同步與通信問題就能解決實時數(shù)據(jù)處理的問題。
在Linux環(huán)境下,進程通常存在運行(running)、阻塞(blocked)、就緒(ready)、終止(terminated)四種狀態(tài)。當(dāng)多個進程并發(fā)執(zhí)行時,往往會出現(xiàn)進程間的競態(tài)。我們希望進程能協(xié)調(diào)彼此間的行為,使得一個進程只有在其他的進程執(zhí)行到一個特定的點時才會執(zhí)行一個動作,即控制同步;同時,當(dāng)并發(fā)進程訪問共享數(shù)據(jù)時不應(yīng)當(dāng)出現(xiàn)競爭條件。這一點通過在訪問共享數(shù)據(jù)時執(zhí)行互斥來確保,即數(shù)據(jù)訪問同步。
實現(xiàn)同步的基本技術(shù)是阻塞一個進程,直到一個特定條件滿足為止;實現(xiàn)數(shù)據(jù)訪問同步是通過阻塞一個進程直到另外的進程完成訪問共享數(shù)據(jù)。
1 有限長度緩沖區(qū)的生產(chǎn)者一消費者問題模型
當(dāng)僅存在單個生產(chǎn)者和消費者時,生產(chǎn)進程和消費進程所對應(yīng)的是同樣的數(shù)據(jù)結(jié)構(gòu),它們共享同一個數(shù)據(jù)空間。生產(chǎn)進程和消費進程如何進行相互協(xié)調(diào),使得消費進程每次使用的數(shù)據(jù)都是生產(chǎn)進程新生產(chǎn)寫人的,又使生產(chǎn)進程新寫入的數(shù)據(jù)不會覆蓋還未被消費進程讀出使用的數(shù)據(jù),是該問題模型實現(xiàn)的關(guān)鍵問題。
在生產(chǎn)者一消費者問題模型中,生產(chǎn)者進程不斷生產(chǎn)產(chǎn)品并把它們放入緩沖區(qū),消費者進程不斷從緩沖區(qū)中取走產(chǎn)品進行消費。當(dāng)緩沖區(qū)中產(chǎn)品已經(jīng)放滿時,表示生產(chǎn)速度高于消費速度,出現(xiàn)了供過于求,此時生產(chǎn)者必須等待產(chǎn)品被消費;當(dāng)緩沖區(qū)為空時,表示消費速度高于生產(chǎn)速度,出現(xiàn)了供不應(yīng)求,此時消費者進程必須等待產(chǎn)品的生產(chǎn)。生產(chǎn)和消費的進程必須達到同步運行,才能實現(xiàn)供需平衡。
處理讀寫同步的兩種常見的策略被稱為“強讀者同步(strong reader synchronization)”和“強寫者同步(strongwriter synchronization)”。在強讀者同步中,總是給讀者以優(yōu)先權(quán),只要寫者當(dāng)前沒有進行寫操作,讀者就可以獲得訪問權(quán);在強寫者同步中,寫者總是獲得優(yōu)先權(quán),只要強讀者當(dāng)前沒有進行讀操作,寫者就可以獲得訪問權(quán)。而生產(chǎn)者消費者同步與單純的讀寫同步又有不同,消費者可以通過訪問資源對資源進行刪除或銷毀。
一個有限長度緩沖區(qū)的生產(chǎn)者消費者問題模型,是由若干生產(chǎn)者和消費者進程以及一個有限的緩沖池構(gòu)成的。每個緩沖區(qū)能夠存儲一個信息記錄,一個生產(chǎn)者一次生產(chǎn)一個信息記錄。產(chǎn)生一個記錄之后,等待單獨進入一個空的緩沖區(qū)后將記錄寫入緩沖區(qū)。一個消費者進程一次消費一個信息記錄。當(dāng)它需要消費時,它等待單獨進入一個滿的緩沖區(qū)后將記錄讀出。
通過上面的描述可以得出,解決生產(chǎn)者一消費者問題模型的方案需要滿足以下幾個條件:
◇生產(chǎn)者不應(yīng)覆蓋一個滿的緩沖區(qū);
◇消費者不應(yīng)使用一個空的緩沖區(qū);
◇生產(chǎn)者和消費者應(yīng)按互斥方式訪問數(shù)據(jù)緩沖區(qū);
◇數(shù)據(jù)必須按照先進先出(FIFO)方式;
◇不能出現(xiàn)忙等待。
必須避免數(shù)據(jù)寫進程不斷、反復(fù)地檢查緩沖區(qū)直到找到一個空緩沖區(qū)為止,而讀進程也必須避免不斷檢查直到找到一個滿緩沖區(qū)為止。這相當(dāng)于系統(tǒng)內(nèi)部產(chǎn)生忙等待,是在僅使用臨界段(CS)算法實現(xiàn)進程同步時難以避免的問題。
針對問題模型解決方案的限制條件,采用信號量方式解決實時更新數(shù)據(jù)處理的進程同步問題,即上述的生產(chǎn)者一消費者問題模型。
信號量是一個非負值的共享整數(shù)值,只能用于初始化和不可分操作。不可分操作是指在對一個數(shù)據(jù)D進行操作時不能與任何其他對D的操作重疊的操作。定義操作P和V為不可分操作。P和V的不可分性意味著這些操作不能并發(fā)執(zhí)行,避免了對信號量的競爭條件。定義P和V的操作語義為:
由上述定義的語義看,對一個信號量S的操作,P和V為改變S的值,或者掛起或喚醒一個對S進行P操作的進程。被掛起的進程為阻塞狀態(tài),因而避免了忙等待問題。一個二進制的信號量只取0和1,用來實現(xiàn)互斥。
在P和V操作中,對進程的阻塞和喚醒需要操作系統(tǒng)的進程管理組件的參與,因此信號量會被操作系統(tǒng)實現(xiàn)而不是應(yīng)用程序?qū)崿F(xiàn)。
在對實時采集更新的數(shù)據(jù)進行處理時,往往會遇到數(shù)據(jù)更新速度與數(shù)據(jù)處理的速度不匹配的問題。這種情況下,會出現(xiàn)數(shù)據(jù)丟失而導(dǎo)致數(shù)據(jù)處理結(jié)果不準(zhǔn)確,甚至?xí)聿豢深A(yù)測的后果,因此需要一種機制來協(xié)調(diào)數(shù)據(jù)更新與數(shù)據(jù)處理,從而保證數(shù)據(jù)的完整性和處理結(jié)果的準(zhǔn)確性。作為一個多任務(wù)、多用戶操作系統(tǒng),Linux支持多個進程在系統(tǒng)中并發(fā)運行,由于進程本身的動態(tài)特性,用來描述實時數(shù)據(jù)處理非常合適,因此,解決好Linux進程間的同步與通信問題就能解決實時數(shù)據(jù)處理的問題。
在Linux環(huán)境下,進程通常存在運行(running)、阻塞(blocked)、就緒(ready)、終止(terminated)四種狀態(tài)。當(dāng)多個進程并發(fā)執(zhí)行時,往往會出現(xiàn)進程間的競態(tài)。我們希望進程能協(xié)調(diào)彼此間的行為,使得一個進程只有在其他的進程執(zhí)行到一個特定的點時才會執(zhí)行一個動作,即控制同步;同時,當(dāng)并發(fā)進程訪問共享數(shù)據(jù)時不應(yīng)當(dāng)出現(xiàn)競爭條件。這一點通過在訪問共享數(shù)據(jù)時執(zhí)行互斥來確保,即數(shù)據(jù)訪問同步。
實現(xiàn)同步的基本技術(shù)是阻塞一個進程,直到一個特定條件滿足為止;實現(xiàn)數(shù)據(jù)訪問同步是通過阻塞一個進程直到另外的進程完成訪問共享數(shù)據(jù)。
1 有限長度緩沖區(qū)的生產(chǎn)者一消費者問題模型
當(dāng)僅存在單個生產(chǎn)者和消費者時,生產(chǎn)進程和消費進程所對應(yīng)的是同樣的數(shù)據(jù)結(jié)構(gòu),它們共享同一個數(shù)據(jù)空間。生產(chǎn)進程和消費進程如何進行相互協(xié)調(diào),使得消費進程每次使用的數(shù)據(jù)都是生產(chǎn)進程新生產(chǎn)寫人的,又使生產(chǎn)進程新寫入的數(shù)據(jù)不會覆蓋還未被消費進程讀出使用的數(shù)據(jù),是該問題模型實現(xiàn)的關(guān)鍵問題。
在生產(chǎn)者一消費者問題模型中,生產(chǎn)者進程不斷生產(chǎn)產(chǎn)品并把它們放入緩沖區(qū),消費者進程不斷從緩沖區(qū)中取走產(chǎn)品進行消費。當(dāng)緩沖區(qū)中產(chǎn)品已經(jīng)放滿時,表示生產(chǎn)速度高于消費速度,出現(xiàn)了供過于求,此時生產(chǎn)者必須等待產(chǎn)品被消費;當(dāng)緩沖區(qū)為空時,表示消費速度高于生產(chǎn)速度,出現(xiàn)了供不應(yīng)求,此時消費者進程必須等待產(chǎn)品的生產(chǎn)。生產(chǎn)和消費的進程必須達到同步運行,才能實現(xiàn)供需平衡。
處理讀寫同步的兩種常見的策略被稱為“強讀者同步(strong reader synchronization)”和“強寫者同步(strongwriter synchronization)”。在強讀者同步中,總是給讀者以優(yōu)先權(quán),只要寫者當(dāng)前沒有進行寫操作,讀者就可以獲得訪問權(quán);在強寫者同步中,寫者總是獲得優(yōu)先權(quán),只要強讀者當(dāng)前沒有進行讀操作,寫者就可以獲得訪問權(quán)。而生產(chǎn)者消費者同步與單純的讀寫同步又有不同,消費者可以通過訪問資源對資源進行刪除或銷毀。
一個有限長度緩沖區(qū)的生產(chǎn)者消費者問題模型,是由若干生產(chǎn)者和消費者進程以及一個有限的緩沖池構(gòu)成的。每個緩沖區(qū)能夠存儲一個信息記錄,一個生產(chǎn)者一次生產(chǎn)一個信息記錄。產(chǎn)生一個記錄之后,等待單獨進入一個空的緩沖區(qū)后將記錄寫入緩沖區(qū)。一個消費者進程一次消費一個信息記錄。當(dāng)它需要消費時,它等待單獨進入一個滿的緩沖區(qū)后將記錄讀出。
通過上面的描述可以得出,解決生產(chǎn)者一消費者問題模型的方案需要滿足以下幾個條件:
◇生產(chǎn)者不應(yīng)覆蓋一個滿的緩沖區(qū);
◇消費者不應(yīng)使用一個空的緩沖區(qū);
◇生產(chǎn)者和消費者應(yīng)按互斥方式訪問數(shù)據(jù)緩沖區(qū);
◇數(shù)據(jù)必須按照先進先出(FIFO)方式;
◇不能出現(xiàn)忙等待。
必須避免數(shù)據(jù)寫進程不斷、反復(fù)地檢查緩沖區(qū)直到找到一個空緩沖區(qū)為止,而讀進程也必須避免不斷檢查直到找到一個滿緩沖區(qū)為止。這相當(dāng)于系統(tǒng)內(nèi)部產(chǎn)生忙等待,是在僅使用臨界段(CS)算法實現(xiàn)進程同步時難以避免的問題。
針對問題模型解決方案的限制條件,采用信號量方式解決實時更新數(shù)據(jù)處理的進程同步問題,即上述的生產(chǎn)者一消費者問題模型。
信號量是一個非負值的共享整數(shù)值,只能用于初始化和不可分操作。不可分操作是指在對一個數(shù)據(jù)D進行操作時不能與任何其他對D的操作重疊的操作。定義操作P和V為不可分操作。P和V的不可分性意味著這些操作不能并發(fā)執(zhí)行,避免了對信號量的競爭條件。定義P和V的操作語義為:
由上述定義的語義看,對一個信號量S的操作,P和V為改變S的值,或者掛起或喚醒一個對S進行P操作的進程。被掛起的進程為阻塞狀態(tài),因而避免了忙等待問題。一個二進制的信號量只取0和1,用來實現(xiàn)互斥。
在P和V操作中,對進程的阻塞和喚醒需要操作系統(tǒng)的進程管理組件的參與,因此信號量會被操作系統(tǒng)實現(xiàn)而不是應(yīng)用程序?qū)崿F(xiàn)。
下載該資料的人也在下載
下載該資料的人還在閱讀
更多 >
- 永磁同步電機控制解析合集 66次下載
- Linux用戶態(tài)開發(fā)驅(qū)動教程及基礎(chǔ)知識 7次下載
- Linux內(nèi)核進程調(diào)度schedule深入理解的詳細資料說明 5次下載
- 關(guān)于進程與線程的解析PDF文件資料
- Linux教程之進程的概念和進程管理命令的使用 2次下載
- linux進程的深入理解 2次下載
- Linux系統(tǒng)管道和有名管道的通信機制解析 0次下載
- Linux進程調(diào)度的原理解析 1次下載
- 進程間通信之Linux下進程間通信概述 0次下載
- Linux守護進程詳解 0次下載
- Linux進程控制編程 0次下載
- Linux源碼分析系列的進程 32次下載
- LINUX系統(tǒng)下多線程與多進程性能分析
- Linux 2.6進程調(diào)度
- Linux進程管理 0次下載
- 讀寫分離怎么保證數(shù)據(jù)同步 514次閱讀
- Linux內(nèi)核中RCU的用法 1405次閱讀
- Linux中進程、線程和協(xié)程的基礎(chǔ)概念 650次閱讀
- Linux讀寫鎖邏輯解析—Linux為何會引入讀寫鎖? 714次閱讀
- 淺談Linux kernel中的同步機制 745次閱讀
- 如何在Linux使用ps/pstree/top命令查看進程 1666次閱讀
- 三態(tài)模型/五態(tài)模型/七態(tài)模型說明 Linux操作系統(tǒng)的進程狀態(tài)轉(zhuǎn)換 4711次閱讀
- 一行代碼教你如何隱藏Linux進程 2161次閱讀
- Linux:測試進程占用的虛擬內(nèi)存大小 2762次閱讀
- 虛擬機:linux 進程的最大線程個數(shù) 2624次閱讀
- Linux進程調(diào)度時機概念分析 2682次閱讀
- 嵌入式Linux中進程調(diào)度怎樣來解析 666次閱讀
- Linux進程管理:什么是進程?進程的生命周期 7750次閱讀
- 基于嵌入式操作系統(tǒng)Linux環(huán)境中的沒有競爭態(tài)讀寫進程同步設(shè)計 668次閱讀
- 基于Linux進程管理的詳細剖析 3630次閱讀
下載排行
本周
- 1TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費
- 2開關(guān)電源基礎(chǔ)知識
- 5.73 MB | 6次下載 | 免費
- 3100W短波放大電路圖
- 0.05 MB | 4次下載 | 3 積分
- 4嵌入式linux-聊天程序設(shè)計
- 0.60 MB | 3次下載 | 免費
- 5基于FPGA的光纖通信系統(tǒng)的設(shè)計與實現(xiàn)
- 0.61 MB | 2次下載 | 免費
- 6基于FPGA的C8051F單片機開發(fā)板設(shè)計
- 0.70 MB | 2次下載 | 免費
- 751單片機窗簾控制器仿真程序
- 1.93 MB | 2次下載 | 免費
- 8基于51單片機的RGB調(diào)色燈程序仿真
- 0.86 MB | 2次下載 | 免費
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33564次下載 | 免費
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費
- 4開關(guān)電源設(shè)計實例指南
- 未知 | 21548次下載 | 免費
- 5電氣工程師手冊免費下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費
- 7電子制作實例集錦 下載
- 未知 | 8113次下載 | 免費
- 8《LED驅(qū)動電路設(shè)計》 溫德爾著
- 0.00 MB | 6653次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537796次下載 | 免費
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420026次下載 | 免費
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費
- 6電路仿真軟件multisim 10.0免費下載
- 340992 | 191185次下載 | 免費
- 7十天學(xué)會AVR單片機與C語言視頻教程 下載
- 158M | 183278次下載 | 免費
- 8proe5.0野火版下載(中文版免費下載)
- 未知 | 138040次下載 | 免費
評論
查看更多