哈工大李治軍《操作系統》進程同步與信號量筆記

1.什么是信號量?

定義:記錄一些信息(即量),并根據這個信息決定睡眠還是喚醒(即信號)。睡眠和喚醒只是一個信號(相當于0和1)。

2.問題:一種資源的數量是8,這個資源對應的信號量的當前值是2,說明:(B)

A. 有2個進程等待這個資源。? ? ? ? ? ? ? ? //值為-2選A

B. 有2個資源可以使用。????????????????

3.信號量:1965年,由荷蘭學者Dijkstra提出的一種特殊整型變量,量用來記錄,信號用來sleep和wake。

(重要)P在荷蘭語里是test(檢測是否有可用資源),V是increase(增加內容)。

struct semaphore
{int value;    //記錄資源個數PCB *queue;    //記錄等待在該信號量上的進程,使用隊列存儲
}P(semaphore s)    //消費資源(對應生產者生產數據占用內存)
{s.value--;if(s.value < 0) sleep(s.queue);
}V(semaphore s)    //產生資源(對應消費者從內存中取數據)
{s.value++;if(s.value <= 0) wake(s.queue);    //說明上一步value<0,存在進程等待資源,所以喚醒一個
}

4.(重點)用信號量解生產者——消費者問題

int fd = open("buffer.txt");
write(fd, 0, sizeof(int));    //寫in    用文件定義共享緩沖區
write(fd, 0, sizeof(int));    //寫outsemaphore full = 0;    //文件里的內容
semaphore empty = BUFFER_SIZE;    //資源的數量
semaphore mutex = 1;    //互斥(原子操作)Producer(item)
{P(empty);    //檢測是否有可用資源并減1P(mutex);讀入in;將item寫入到in的位置上;V(mutex);V(full);    //讓full的值增加
}Consumer()
{P(full);    //檢測是否有內容P(mutex);讀入out;從文件中的out位置讀出到item;打印item;V(mutex);V(empty);    //可用資源+1
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/80783.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/80783.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/80783.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

MySQL 的索引類型有哪些?

MySQL 中的索引是提高查詢性能的重要工具&#xff0c;它通過構建數據結構來加速數據檢索。MySQL 支持多種索引類型&#xff0c;每種類型適用于不同的場景。以下是 MySQL 中主要的索引類型及其特點&#xff1a; 1. B-Tree 索引&#xff08;默認類型&#xff09; 結構&#xff1…

基于Qt5的藍牙打印開發實戰:從掃描到小票打印的全流程

文章目錄 前言一、應用案例演示二、開發環境搭建2.1 硬件準備2.2 軟件配置 三、藍牙通信原理剖析3.1 實現原理3.2 通信流程3.3 流程詳解3.4 關鍵技術點 四、Qt藍牙核心類深度解析4.1 QBluetoothDeviceDiscoveryAgent4.2 QBluetoothDeviceInfo4.3 QBluetoothSocket 五、功能實現…

高可靠性厚銅板制造的關鍵設備與工藝投入

隨著科技的不斷發展&#xff0c;電子設備越來越普及&#xff0c;對電路板的需求也越來越大。厚銅板電路板作為一種高性能、高可靠性的電路板&#xff0c;受到了廣泛的關注和應用。那么&#xff0c;作為一家厚銅板電路板供應商&#xff0c;如何投入線路板生產呢&#xff1f;本文…

【如何使用solidwork編輯結構導入到simscope】

這里寫自定義目錄標題 嘗試將solidrwork的模型導入到matlab中&#xff0c;以下是官方給出的設計步驟&#xff0c;沖啊 To use Simscape Multibody Link, you must install MATLAB and the CAD applications on the same computer. To ensure the successful installation of Si…

Linux 在個人家目錄下添加環境變量 如FLINK_PROPERTIES=“jobmanager.rpc.address: jobmanager“

問題&#xff1a; Docker Flink Application Mode 命令行形式部署前&#xff0c;需要在Linux執行以下&#xff1a; $ FLINK_PROPERTIES"jobmanager.rpc.address: jobmanager" $ docker network create flink-network 臨時變量只在當前session會話窗口生效&#xf…

spring項目rabbitmq es項目啟動命令

應該很多開發者遇到過需要啟動中間件的情況&#xff0c;什么測試服務器掛了&#xff0c;服務連不上nacos了巴拉巴拉的&#xff0c;雖然是測試環境&#xff0c;但也會手忙腳亂&#xff0c;瘋狂百度。 這里介紹一些實用方法 有各種不同的場景&#xff0c;一是重啟&#xff0c;服…

語音合成之七語音克隆技術突破:從VALL-E到SparkTTS,如何解決音色保真與清晰度的矛盾?

從VALL-E到SparkTTS&#xff0c;如何解決音色保真與清晰度的矛盾&#xff1f; 引言語音克隆技術發展史YourTTS&#xff1a;深入剖析架構與技術VALL-E&#xff1a;揭秘神經編解碼語言模型MaskGCTSparkTTS&#xff1a;利用 LLM 實現高效且可控的語音合成特征解耦生成式模型特征解…

run code執行ts配置

1、全局安裝typescript npm install –g typescript 執行tsc –v&#xff0c;可輸出版本號&#xff0c;代表安裝成功 2、創建tsConfig文件 npx tsc –init 創建成功目錄下會出現tsconfig.json文件 3、安裝ts-node&#xff0c;支持執行運行ts文件 npm install –g ts-node 控制…

splitchunk(如何將指定文件從主包拆分為單獨的js文件)

1. 說明 webpack打包會默認將入口文件引入依賴js打包為一個入口文件&#xff0c;導致這個文件會比較大&#xff0c;頁面首次加載時造成加載時間較長 可通過splitchunk配置相應的規則&#xff0c;對匹配的規則打包為單獨的js,減小入口js的體積 2. 示例 通過正則匹配&#xff…

postgres 導出導入(基于數據庫,模式,表)

在 PostgreSQL 中&#xff0c;導出和導入數據庫、模式&#xff08;schema&#xff09;或表的數據可以使用多種工具和方法。以下是常用的命令和步驟&#xff0c;分別介紹如何導出和導入整個數據庫、特定的模式以及單個表的數據。 一、導出數據 1. 使用 pg_dump 導出整個數據庫…

第十一天 主菜單/設置界面 過場動畫(Timeline) 成就系統(Steam/本地) 多語言支持

前言 對于剛接觸Unity的新手開發者來說&#xff0c;構建完整的游戲系統往往充滿挑戰。本文將手把手教你實現游戲開發中最常見的四大核心系統&#xff1a;主菜單界面、過場動畫、成就系統和多語言支持。每個模塊都將結合完整代碼示例&#xff0c;使用Unity 2022 LTS版本進行演示…

深入探索Python Pandas:解鎖數據分析的無限可能

放在前頭 深入探索Python Pandas&#xff1a;解鎖數據分析的無限可能 深入探索Python Pandas&#xff1a;解鎖數據分析的無限可能 在當今數據驅動的時代&#xff0c;高效且準確地處理和分析數據成為了各個領域的關鍵需求。而Python作為一門強大且靈活的編程語言&#xff0c;…

小集合 VS 大集合:MySQL 去重計數性能優化

小集合 VS 大集合&#xff1a;MySQL 去重計數性能優化 前言一、場景與問題 &#x1f50e;二、通俗執行流程對比三、MySQL 執行計劃解析 &#x1f4ca;四、性能瓶頸深度剖析 &#x1f50d;五、終極優化方案 &#x1f3c6;六、總結 前言 &#x1f4c8; 測試結果&#xff1a; 在…

3、Linux操作系統下,linux的技術手冊使用(man)

linux系統內置技術手冊&#xff0c;方便開發人員查閱Linux相關指令&#xff0c;提升開發效率 man即是manual的前三個字母&#xff0c;有時候遇事不決&#xff0c;問個人&#xff08;man&#xff09; 其在線網址為&#xff1a;man 還有man網站的作者寫的書&#xff0c;可以下…

京東商品詳情數據爬取難度分析與解決方案

在當今數字化商業時代&#xff0c;電商數據對于市場分析、競品研究、價格監控等諸多領域有著不可估量的價值。京東&#xff0c;作為國內首屈一指的電商巨頭&#xff0c;其商品詳情頁蘊含著海量且極具價值的數據&#xff0c;涵蓋商品價格、庫存、規格、用戶評價等關鍵信息。然而…

正確應對監管部門的數據安全審查

首席數據官高鵬律師團隊編著 在當今數字化時代&#xff0c;數據安全已成為企業及各類組織面臨的重要議題&#xff0c;而監管部門的數據安全審查更是關乎其生存與發展的關鍵挑戰。隨著法律法規的不斷完善與監管力度的加強&#xff0c;如何妥善應對這一審查&#xff0c;避免潛在…

三星One UI安全漏洞:剪貼板數據明文存儲且永不過期

三星One UI系統曝出重大安全漏洞&#xff0c;通過剪貼板功能導致數百萬用戶的敏感信息面臨泄露風險。 剪貼板數據永久存儲 安全研究人員發現&#xff0c;運行Android 9及以上系統的三星設備會將所有剪貼板內容——包括密碼、銀行賬戶詳情和個人消息——以明文形式永久存儲&am…

動態規劃求解leetcode300.最長遞增子序列(LIS)詳解

給你一個整數數組 nums &#xff0c;找到其中最長嚴格遞增子序列的長度。 子序列 是由數組派生而來的序列&#xff0c;刪除&#xff08;或不刪除&#xff09;數組中的元素而不改變其余元素的順序。例如&#xff0c;[3,6,2,7] 是數組 [0,3,1,6,2,2,7] 的子序列。 示例 1&#…

Rule.resourceQuery(通過路徑參數指定loader匹配規則)

1. 說明 在 webpack 4 中&#xff0c;Rule.resourceQuery 是一個用于根據文件路徑中的 查詢參數&#xff08;query string&#xff09; 來匹配資源的配置項。它允許你針對帶有特定查詢條件的文件&#xff08;如 file.css?inline 或 image.png?raw&#xff09;應用不同的加載…

快速上手 MetaGPT

1. MetaGPT 簡介 在當下的大模型應用開發領域&#xff0c;Agent 無疑是最炙手可熱的方向&#xff0c;這也直接催生出了眾多的 Agent 開發框架。在這之中&#xff0c; MetaGPT 是成熟度最高、使用最廣泛的開發框架之一。 MetaGPT 是一款備受矚目的多智能體開發框架&#xff0c…