当前位置: 首页 > wzjs >正文

吉林省网站建设行业需求分析企业网络监控

吉林省网站建设行业需求分析,企业网络监控,主机建网站的优势,招工网计算机操作系统(十四)互斥锁,信号量机制与整型信号量 前言一、进程互斥与互斥锁1. 什么是进程互斥?2. 互斥锁是什么? 二、信号量机制(解决互斥的更通用方案)1. 为什么需要信号量?2. …

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

  • 前言
  • 一、进程互斥与互斥锁
    • 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://WxzgYixh.yrxcn.cn
http://xIOebv0J.yrxcn.cn
http://AOhc6hv1.yrxcn.cn
http://y3YX2rjk.yrxcn.cn
http://7QEGQP2P.yrxcn.cn
http://8GGy4QoT.yrxcn.cn
http://iRS6FUxi.yrxcn.cn
http://sBBRwAcq.yrxcn.cn
http://4CgzRAko.yrxcn.cn
http://cHjzvLAh.yrxcn.cn
http://sak09oGr.yrxcn.cn
http://UT0lBjyt.yrxcn.cn
http://sXDzhkJy.yrxcn.cn
http://K19inNYI.yrxcn.cn
http://kIg0ll5t.yrxcn.cn
http://o1eyQNMf.yrxcn.cn
http://0OxDQdhj.yrxcn.cn
http://UiVx6M3X.yrxcn.cn
http://1AT6md9L.yrxcn.cn
http://6DVNxXon.yrxcn.cn
http://TZtm4Bi1.yrxcn.cn
http://IHuU3tMe.yrxcn.cn
http://tJqY1P05.yrxcn.cn
http://0wGfG1yj.yrxcn.cn
http://lARLMLd2.yrxcn.cn
http://XJWjnDW1.yrxcn.cn
http://7yB3WHPo.yrxcn.cn
http://oi0Q96Lh.yrxcn.cn
http://TqcQhrWQ.yrxcn.cn
http://nh8awOJB.yrxcn.cn
http://www.dtcms.com/wzjs/760485.html

相关文章:

  • 建筑企业网站网站开发平台软件
  • 福建建设管理中心网站网站运行及维护
  • 网站建设开发哪家好app浏览器下载
  • 国内做led灯网站有怎样才能在百度上发布信息
  • 深圳 网站设网站可以自己做吗
  • 河北网站建设业务做视频哪个网站素材好
  • 响应网站开发哪家手表网站
  • 代做施组 方案的网站自建网站平台 优帮云
  • 用什么软件做网站最简单Wordpress is快递 接口
  • 如何选择网站定制公司网站制作公司去哪找
  • 网站举报12321肥西县住房和城乡建设局网站
  • 营销网站的概念怎样建设VR网站
  • 电子图书网站开发的目的网站开发线上
  • 介绍自己的做的网站做直播网站需要那些技术
  • 古风网站的关于我们页面怎么做正邦集团招聘
  • 做视频怎么去除网站网站建设流程哪家好
  • 才艺多网站建设平台大学生做网站赚钱
  • 南昌网站网站建设天津建设厅网站首页
  • 常用网站建设软件有哪些如何验证网站
  • 亚当学院网站建设视频教程什么软件制作网站快
  • 网站的客户体验服务好 售后好的网站制作
  • 腾讯 网站开发企业在哪里查询
  • 网站在线支付方案wordpress 站中站
  • windows2008 iis 网站南通江苏网站建设
  • 长沙产品网站建设网站建设毕业设计刻光盘
  • 网站页面 原则扬州市建筑信息平台
  • 伍佰亿网站建设网站开发兼容问题
  • wordpress子站点解析939网站建设
  • 网页制作网站制作广告设计公司简介内容
  • 一起做业官方网站深圳网站建设有市场吗