2.3.2 信号量机制——操作系统笔记


1. 信号量机制

用户进程可以通过使用操作系统提供的一对原语来对信号量进行操作。

信号量其实就是一个变量(可以是一个整数,也可以是更复杂的记录型变量),可以用一个信号量来表示系统中某种资源的数量。
一对原语:wait(S)和signal(S),简称为P、V操作。

  • 整型信号量 在这里插入图片描述

  • 记录型信号量

    整型信号量的缺陷是存在“忙等”问题,记录型信号量用记录型数据结构表示的信号量
    在这里插入图片描述

2. 信号量机制实现进程互斥

  1. 分析并发进程的关键活动,划定临界区

  2. 设置互斥信号量mutex,初值为1

  3. 在进入区P(mutex) 申请资源

  4. 在退出区V(mutex) 释放资源

    	semaphore mutex=1;
    		
    	P1(){
    		...
    		P(mutex);  //使用临界资源前需要加锁
    		临界区代码段...
    		V(mutex); //使用临界资源后需要解锁
    		...
    	}
    		
    	P2(){
    		...
    		P(mutex);
    		临界区代码段...
    		V(mutex);
    		...
    	}
    

3. 信号量机制实现进程同步

进程同步:要让各并发进程按要求有序地推进

  1. 分析在什么地方需要实现“同步关系”,即必须保证“一前一后”执行的两个操作
  2. 设置同步信号量S,初始为0
  3. 在“前操作”之后执行V(S)
  4. 在“后操作”之前执行P(S)
    在这里插入图片描述

4. 信号量机制实现前驱关系

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值