国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

電子發燒友App

硬聲App

掃碼添加小助手

加入工程師交流群

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

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

3天內不再提示
電子發燒友網>電子資料下載>嵌入式開發>Linux中的進程同步無競爭態讀寫解析

Linux中的進程同步無競爭態讀寫解析

2017-11-06 | rar | 0.5 MB | 次下載 | 1積分

資料介紹

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

掃碼添加小助手

加入工程師交流群

下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1冷柜-電氣控制系統講解
  2. 13.68 MB  |  4次下載  |  10 積分
  3. 2安川A1000變頻器中文版說明書
  4. 20.16 MB  |  3次下載  |  3 積分
  5. 3直流電路的組成和基本定律
  6. 1.67 MB   |  2次下載  |  免費
  7. 4丹佛斯2800系列變頻器說明書
  8. 8.00 MB  |  1次下載  |  5 積分
  9. 5PC8011同步開關型降壓3.5A單節鋰電池充電管理電路技術手冊
  10. 0.74 MB   |  1次下載  |  免費
  11. 6ES7243E+ES8311音頻錄制與播放電路資料
  12. 0.06 MB   |  1次下載  |  5 積分
  13. 7SDM02 激光測距模塊產品手冊
  14. 0.43 MB   |  1次下載  |  免費
  15. 8SDFM 激光測距模塊模組手冊
  16. 0.54 MB   |  1次下載  |  免費

本月

  1. 1CH341編程器軟件NeoProgrammer_2.2.0.10
  2. 20.47 MB   |  170次下載  |  1 積分
  3. 22025智能家居傳感器市場分析及創新應用
  4. 3.11 MB  |  43次下載  |  免費
  5. 3RV1126B系列開發板產品資料
  6. 4.19 MB  |  18次下載  |  免費
  7. 4CH341編程軟件下載
  8. 2.50 MB   |  16次下載  |  5 積分
  9. 5全志系列-米爾基于T153核心板開發板 四核異構、3路千兆網,賦能多元化工業場景
  10. 3.05 MB  |  12次下載  |  免費
  11. 6【開源】60余套STM32單片機、嵌入式Linux、物聯網、人工智能項目案例及入門學習資源包
  12. 10.55 MB  |  8次下載  |  免費
  13. 7冷柜-電氣控制系統講解
  14. 13.68 MB  |  4次下載  |  10 積分
  15. 8特斯拉MODEL S車載充電機主電路回路原理圖
  16. 0.81 MB   |  4次下載  |  3 積分

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935137次下載  |  10 積分
  3. 2開源硬件-PMP21529.1-4 開關降壓/升壓雙向直流/直流轉換器 PCB layout 設計
  4. 1.48MB  |  420064次下載  |  10 積分
  5. 3Altium DXP2002下載入口
  6. 未知  |  233094次下載  |  10 積分
  7. 4電路仿真軟件multisim 10.0免費下載
  8. 340992  |  191448次下載  |  10 積分
  9. 5十天學會AVR單片機與C語言視頻教程 下載
  10. 158M  |  183356次下載  |  10 積分
  11. 6labview8.5下載
  12. 未知  |  81604次下載  |  10 積分
  13. 7Keil工具MDK-Arm免費下載
  14. 0.02 MB  |  73824次下載  |  10 積分
  15. 8LabVIEW 8.6下載
  16. 未知  |  65991次下載  |  10 積分