计算机操作系统(十四)互斥锁,信号量机制与整型信号量

article/2025/8/26 0:14:17

计算机操作系统(十四)互斥锁,信号量机制与整型信号量

  • 前言
  • 一、进程互斥与互斥锁
    • 1. 什么是进程互斥?
    • 2. 互斥锁是什么?
  • 二、信号量机制(解决互斥的更通用方案)
    • 1. 为什么需要信号量?
    • 2. 信号量是什么?
    • 2. 整型信号量
      • 2.1 什么是整型信号量?
    • 3. 记录性信号量
      • 3.1 什么是记录性信号量?


前言

  • 在上一篇博客中,我们通过简单的代码初步了解了进程同步和进程互斥的概念,以及进程互斥的硬件实现方法。
  • 本文将继续深入探讨并发编程中的重要机制,包括互斥锁、信号量机制以及整型信号量的具体应用

我的个人主页,欢迎来阅读我的其他文章
https://blog.csdn.net/2402_83322742?spm=1011.2415.3001.5343
我的操作系统博客专栏
https://blog.csdn.net/2402_83322742/category_12916780.html?spm=1001.2014.3001.5482


一、进程互斥与互斥锁

1. 什么是进程互斥?

多个进程(或线程)同时访问共享资源(如打印机、变量)时,需要保证同一时刻只有一个进程使用资源,否则会导致混乱(比如多个进程同时修改同一数据,结果出错)。
例子:多个同学排队用一台打印机,每次只能有一人打印,其他人必须等待。

2. 互斥锁是什么?

互斥锁就像一把“钥匙”,确保同一时刻只有一个进程持有钥匙(占用资源),其他进程必须等待。

  • 特点
    • 忙等待(自旋锁):没拿到锁的进程会不断循环检查锁是否可用,不做其他事(“干等”)。
    • 优点:简单高效,适合多处理器系统(等待的进程可在其他核心继续运行)。
    • 缺点:在单处理器系统中效率低(等待时占用CPU,无法解锁)。
  • 适用场景:多核心CPU下的快速资源竞争(如短时间占用的资源)。

二、信号量机制(解决互斥的更通用方案)

1. 为什么需要信号量?

互斥锁只能解决“互斥”(一次只能一个进程用资源),但现实中可能有多个同类资源(如3台打印机),或需要协调进程间的“先后顺序”(如生产者-消费者问题)。信号量能更灵活地管理这类场景。

2. 信号量是什么?

  • 本质:一个整数变量(记为 s),表示系统中某种资源的剩余数量状态
  • 核心操作
    • wait(s)(申请资源):
      • 如果 s > 0,表示有资源可用,s 减1,进程继续执行。
      • 如果 s ≤ 0,表示无资源,进程阻塞等待(不占用CPU,直到资源释放)。
    • signal(s)(释放资源):
      • s 加1,唤醒等待该资源的进程。
  • 关键特性
    • 原语操作waitsignal 的执行必须一气呵成(中途不能被打断),通过硬件指令(如关中断)保证原子性。
    • 解决忙等待问题:进程阻塞时不占用CPU,比互斥锁的“忙等待”更高效。

2. 整型信号量

2.1 什么是整型信号量?

  • 它是信号量的 简化版,本质就是一个 整数变量(比如 int semaphore = 10)。
  • 靠两个原子操作(不可中断的操作)控制资源:
    • P操作(申请资源):想占用资源时,先把计数器减1。
      • 如果减完后 计数器 ≥ 0:说明有资源,允许进入。
      • 如果减完后 计数器 < 0:说明没资源,原地循环等待(忙等)。
    • V操作(释放资源):用完资源后,把计数器加1。
      • 如果加完后 计数器 ≤ 0:说明有其他进程在等待,唤醒一个等待的进程。

举个例子
假设桌子数量 semaphore = 1(互斥锁场景,比如打印机一次只能被一个进程用):

  • 进程A 来申请资源(P操作):semaphore 变成0,≥0,允许使用。
  • 进程B 来申请资源(P操作):semaphore 变成-1,<0,只能疯狂循环检查 semaphore 是否变回≥0(像个傻子一样一直问“好了吗?好了吗?”)。
  • 进程A 用完释放(V操作):semaphore 变回0,此时发现有进程在等待(因为-1<0),唤醒进程B。
  • 进程B 继续执行,占用资源。

缺点:忙等太浪费!

  • 忙等:进程B在等待时,一直占用CPU资源(像个不停敲门的人),导致CPU效率低下。
  • 不适合大量进程竞争:如果有100个进程等资源,100个都在疯狂循环,电脑直接卡爆。

3. 记录性信号量

3.1 什么是记录性信号量?

  • 为了解决整型信号量的忙等问题,引入了一个 结构体 来记录更多信息,比如:
    struct semaphore {int value;          // 资源数量(比如剩余桌子数)struct process* list;  // 等待队列(记录哪些进程在排队)
    };
    
  • P操作和V操作的逻辑变了
    • P操作
      1. value 减1。
      2. 如果 value < 0,说明没资源,把当前进程加入等待队列,然后 阻塞(暂停执行),释放CPU(像留个电话,去干别的事)。
    • V操作
      1. value 加1。
      2. 如果 value ≤ 0,说明等待队列里有进程在等,唤醒队列中的第一个进程(打电话叫人回来)。

2举个例子
还是桌子数量 value = 1

  • 进程A 申请资源(P操作):value 变0,≥0,允许使用。
  • 进程B 申请资源(P操作):value 变-1,<0,被加入等待队列,进入阻塞状态(不占用CPU,去睡觉了)。
  • 进程A 释放资源(V操作):value 变0,发现等待队列有进程B,唤醒B。
  • 进程B 被唤醒后,从阻塞状态变为就绪状态,等待CPU调度后继续执行。

优点:不忙等,更高效!

  • 阻塞代替忙等:等待的进程不占用CPU,CPU可以去处理其他任务,资源利用率更高。
  • 清晰的排队机制:通过等待队列管理进程,避免混乱,符合“先来先服务”的公平性。

总结

特性整型信号量记录性信号量
数据结构整数(int)结构体(含value和等待队列)
等待方式忙等(循环检查,浪费CPU)阻塞(加入队列,不占CPU)
公平性无队列,可能导致“饥饿”有队列,按顺序唤醒,更公平
适用场景简单场景(如少量进程互斥)复杂场景(如大量进程竞争)

以上就是对本次关于操作系统博客内容的总结,后续我们将深入探讨操作系统更多知识。

我的个人主页,欢迎来阅读我的其他文章
https://blog.csdn.net/2402_83322742?spm=1011.2415.3001.5343
我的操作系统博客专栏
https://blog.csdn.net/2402_83322742/category_12916780.html?spm=1001.2014.3001.5482

非常感谢您的阅读,喜欢的话记得三连哦

在这里插入图片描述


http://www.hkcw.cn/article/JfWqPycgri.shtml

相关文章

铸铁平台的优势和应用

铸铁平台是一种具有广泛应用的工业设备&#xff0c;其在各个领域均发挥着重要作用。本文将探讨铸铁平台的优势和应用&#xff0c;以帮助读者更好地了解这一重要设备。 一、铸铁平台的优势 强度高&#xff1a;铸铁平台采用高强度铸铁材料制成&#xff0c;具有优异的强度和耐磨性…

EfficMultiCoreMemoryPool项目

目录 1. 定长内存池介绍 2. tcmalloc整体框架了解 2.1 ThreadCache设计 各区间内存浪费分析 2.1.1 ThreadCache申请内存 2.1.2 ThreadCache释放内存 2.1.3 TLS线程局部变量 2.2 CentralCache设计 2.2.1 CentralCache申请内存 ThreadCache --> CentralCache的申请内…

【Doris基础】Apache Doris vs 传统数据仓库:架构与性能的全面对比

目录 1 引言 1.1 传统数据仓库的发展 1.2 现代分析型数据库的崛起 2 核心架构对比 2.1 传统数据仓库的架构 2.2 Doris的架构设计 3 关键技术差异 3.1 存储引擎对比 3.2 查询执行对比 3.3 数据摄入方式对比 4 性能与扩展性对比 4.1 性能基准对比 4.2 扩展性对比 5…

字符串转换函数-leetCode-008

问题描述&#xff1a; 实现一个将字符串转换为整数的函数时&#xff0c;需要考虑各种边界情况和细节&#xff0c;例如空格的处理、符号的判断、数字的读取以及整数溢出的处理等。以下是详细的解题过程以及代码实现。 问题分析 空格处理&#xff1a;需要丢弃字符串开头的空格字…

深度学习目标检测实战——YOLOv8从入门到部署

本文将手把手带你用 YOLOv8&#xff08;目前非常先进的目标检测框架&#xff09;实现从数据标注到模型部署的全流程实战&#xff0c;并达到工业级检测精度&#xff01; [yolo视频教程&#xff0c;戳蓝字即可学习] 这才是科研人该学的【YOLO算法全系列】&#xff0c;一口气学完…

C#对象集合去重的一种方式

前言 现在AI越来越强大了&#xff0c;有很多问题其实不需要在去各个网站上查了&#xff0c;直接问AI就好了&#xff0c;但是呢&#xff0c;AI给的代码可能能用&#xff0c;也可能需要调整&#xff0c;但是自己肯定是要会的&#xff0c;所以还是总结一下吧。 问题 如果有一个…

[ctfshow web入门] web124

信息收集 error_reporting(0); //听说你很喜欢数学&#xff0c;不知道你是否爱它胜过爱flag if(!isset($_GET[c])){show_source(__FILE__); }else{//例子 c20-1$content $_GET[c];// 长度不允许超过80个字符if (strlen($content) > 80) {die("太长了不会算");}/…

AI生成思维导图全技术解析

一、AI生成思维导图的底层技术逻辑 (一)知识结构化的核心流程 AI生成思维导图的本质是非结构化文本到结构化知识图谱的转化,其技术流程可拆解为五大核心环节: 1. 语义解析与实体抽取 多模态输入处理:支持文本(Markdown/Word/PDF)、语音(会议录音)、手写笔记(图片O…

秋招Day12 - 计算机网络 - 网络综合

从浏览器地址栏输入URL到显示网页的过程了解吗&#xff1f; 从在浏览器地址栏输入 URL 到显示网页的完整过程&#xff0c;并不是一个单一的数据包从头到尾、一次性地完成七层封装再七层解析的过程。 而是涉及到多次、针对不同目的、与不同服务器进行的、独立的网络通信交互&a…

SpringBoot集成第三方jar的完整指南

原文地址&#xff1a;https://blog.csdn.net/weixin_43826336/article/details/141640152?ops_request_misc%257B%2522request%255Fid%2522%253A%25227d4118ef2d572ba4428caf83f1d2bb28%2522%252C%2522scm%2522%253A%252220140713.130102334…%2522%257D&request_id7d4118…

官宣开源!通过 AI 驱动的前后端 Java Vue 脚手架(AI 后台管理)正式发布!

&#xff08;在本帖评论点赞关注的小伙伴&#xff0c;今日可得好运相随&#xff0c;会有好事发生&#xff0c;不信试试看&#xff5e;&#xff09; &#x1f525; 知路后台管理 - 通过 AI 驱动的新一代前后端脚手架 知路是一个原生集成 AI 并通过 AI 驱动的重新构思、重新设计…

什么是VR全景相机?如何选择VR全景相机?

VR全景相机的定义、原理及特点 定义&#xff1a;VR全景相机是利用特殊镜头设计和图像处理技术&#xff0c;能够捕捉到360度全方位、无死角的高清影像&#xff0c;并通过虚拟现实技术将用户带入沉浸式全景环境的相机设备。 原理&#xff1a;VR全景相机通过集成多个鱼眼镜头&am…

vr中风--数据处理模型搭建与训练2

位置http://localhost:8888/notebooks/Untitled1-Copy1.ipynb # -*- coding: utf-8 -*- """ MUSED-I康复评估系统&#xff08;增强版&#xff09; 包含&#xff1a;多通道sEMG数据增强、混合模型架构、标准化处理 """ import numpy as np impor…

数控技术应用理实一体化平台VR实训系统

::产品概述:: 目前我国本科类院校学生普遍存在的问题就是缺少对实际工作的了解&#xff0c;一直在学习相关专业的理论知识&#xff0c;对社会的相关企业的用人情况不了解。这也就直接导致了毕业的学生和社会上的用人单位需求有点脱节&#xff0c;这也是由于我国的现行本科教育侧…

上传图片转成3D VR效果 / 用photo-sphere-viewer实现图片VR效果

系统简介 : 该系统为 react TS tailwindcss photo-sphere-viewer 的响应式 VR360 项目, 上传图片后可实现手动旋转 3D 图片,还包含了 6 贴图立方体展示和 6 贴图动态展示 目前为单图切换模式 全部页面概览 这是单面VR页面的代码(gif展示页面) import React, { useRef, u…

若依微服务的定制化服务

复制依赖 复制依赖 复制system服务的bootstrap.yml文件&#xff0c;修改port和name 在nacos复制一个新的nacos配置&#xff0c;修改对应的nacos的配置 &#xff0c;可能不需要修改&#xff0c;看情况。 网关修改 注意curd的事项&#xff0c;模块名称的修改

python和风api获取天气(JSON Web Token)

下载安装openssl 默认安装目录&#xff0c;添加C:\Program Files\OpenSSL-Win64\bin到用户Path环境变量 打开cmd&#xff0c;执行命令&#xff0c;会生成两个文件ed25519-private.pem&#xff0c;ed25519-public.pem openssl genpkey -algorithm ED25519 -out ed25519-privat…

【案例分享】蓝牙红外线影音遥控键盘:瑞昱RTL8752CJF

蓝牙红外线影音遥控键盘 Remotec的无线控制键盘采用瑞昱蓝牙RTL8752CJF解决方案&#xff0c;透过蓝牙5.0与手机配对后&#xff0c;连线至 Remotec 红外 code server 取得对应影音视觉设备的红外 code后&#xff0c;即可控制多达2个以上的影音视觉设备&#xff0c;像是智能电视…

Codeforces Round 1025 (Div. 2)

Problem - A - Codeforces 查有没有人说谎&#xff0c;有一个必错的情况&#xff1a; 两个人都说输了&#xff0c;必有人撒谎&#xff0c;还有就是所有人都赢了&#xff0c;也是撒谎 来看代码&#xff1a; #include <iostream> #include <vector> using namespa…

mqtt协议连接阿里云平台

首先现在的阿里云物联网平台已经不在新购了&#xff0c;如下图所示&#xff1a; 解决办法&#xff1a;在咸鱼上租用一个账号&#xff0c;先用起来。 搭建阿里云平台&#xff0c;参考博客&#xff1a; &#xff08;一&#xff09;MQTT连接阿里云物联网平台&#xff08;小白向&…