操作系統-信號量臨界區保護

来源:https://www.cnblogs.com/mengd/archive/2020/03/17/12513663.html
-Advertisement-
Play Games

什麼是信號量?通過對這個量的訪問和修改,讓大家有序推進 1. 共同修改信號量引出的問題 2. 競爭條件 3. 解決競爭條件的直觀想法 4. 臨界區 臨界區:臨界區是指進程中的一段需要訪問共用資源並且另一個進程處於相應代碼區域時便不會被執行的代碼區域 互斥:當一個進程處於臨界區並訪問共用資源時,沒有其 ...


什麼是信號量?通過對這個量的訪問和修改,讓大家有序推進

1. 共同修改信號量引出的問題

2. 競爭條件

3. 解決競爭條件的直觀想法

4. 臨界區

臨界區:臨界區是指進程中的一段需要訪問共用資源並且另一個進程處於相應代碼區域時便不會被執行的代碼區域

互斥:當一個進程處於臨界區並訪問共用資源時,沒有其他進程會處於臨界區並且訪問任何相同的共用資源

臨界區代碼的保護原則

5. 臨界區嘗試一:輪換法

如果turn=0,那就進入執行,turn!=0,那就空轉

6. 臨界區的嘗試二:標記法

代碼實現:

p0進入先打標記,如果發現p1也打標記了,那麼就空轉,等p1執行完flag[1] = false , p0再進入執行

標記法引發的問題:

7. 臨界區的嘗試三:非對稱標記

Peterson演算法

Peterson演算法的正確性

8. 保護臨界區方法一

麵包店演算法

麵包店演算法的正確性:

9. 保護臨界區方法二

硬體實現:開關中斷

僅限用於但處理器

cli(); 關中斷

sti(); 開中斷

但多cpu不好使:因為當前的cpu只能控制當前的進程

10. 保護臨界區方法三

硬體原子指令法

單處理器和多處理器均可

就是類似於鎖的那種,但是這個是一次執行完畢,上鎖過程不會被打斷


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 我要開始魔鬼排版了。按點列出自己需要註意的部分。 為了區分標識符中的單詞,將每個單詞的首字母大寫,不要用下劃線來區分單詞,也不要在標識符的任何位置使用下劃線。 除參數以外的標識符,將每個單詞的第一個字元大寫,如,HtmlTag;如果是兩個字母的首字母縮略詞,兩個字母都大寫,如,IOStream 作為 ...
  • 使用Guget 添加Microsoft.AspNetCore.Mvc.Versioning 包引用,由於我的.netcore是2.1版本,避免出現不相容問題,版本添加我選的也是2.1版本 在Startup.cs中的 public void ConfigureServices(IServiceColl ...
  • 1.自定義列印類 2.調用 ...
  • 慄子: 一、 PrintDialog 1. showDialog():顯示列印設置 2. PrintableAreaWidth、PrintableAreaHeight:獲取列印紙的寬高,單位為1/96英寸 二、DrawingVisusual RenderOpen():生成DrawingContext ...
  • SharpDevelop是一款開源的輕量級IDE,它支持眾多的語言及項目開發。可以看看支持的項目。 程式本體僅十幾MB,打開項目速度飛快。 目前SharpDevelop最高支持C# 5.0,.NET Framework 4.5.2,非常適合初學者以及電腦配置不高的同學使用。 使用方法:①通過VS20 ...
  • 場景 首先獲取設備硬碟的捲標號,然後獲取CPU的序列號,將這兩個拼接成機器碼。 註: 博客主頁: https://blog.csdn.net/badao_liumang_qizhi 關註公眾號 霸道的程式猿 獲取編程相關電子書、教程推送與免費下載。 實現 新建一個Winform程式,然後添加Mana ...
  • 場景 MD5加密登錄密碼效果 註: 博客主頁: https://blog.csdn.net/badao_liumang_qizhi 關註公眾號 霸道的程式猿 獲取編程相關電子書、教程推送與免費下載。 實現 新建Winform程式並添加System.Web引用 然後新建一個登錄頁面,並設計登錄頁面佈局 ...
  • 一 Controller Manager原理 1.1 Controller Manager概述 一般來說,智能系統和自動系統通常會通過一個“控制系統”來不斷修正系統的工作狀態。在Kubernetes集群中,每個Controller都是這樣的一個“控制系統”,它們通過API Server提供的(Lis ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...