操作系统学习笔记(二十一):信号量

本文介绍了信号量作为进程间通信方式的角色,强调其在资源管理中的作用。信号量包含P()和V()操作,确保对共享资源的原子性访问。文章探讨了信号量的公平性原则以及二进制和资源信号量的区别,并通过举例说明了信号量在互斥访问和条件同步中的应用,如生产者消费者模型的问题和解决方案。
摘要由CSDN通过智能技术生成

      信号量与管程也是进程间通信的方式。信号量是与锁在同一层级实现的,是操作系统提供的一种协调共享资源访问的方法。信号量由操作系统管理,操作系统作为管理者地位是高于进程的。

      信号也是一种抽象的数据类型,由一个整型变量(sem)和两个原子操作组成。P()操作使sem减一,若sem<0进入等待,否则继续。V()操作使sem加一,如果加一后sem仍然小于等于零,代表还有线程在等待使用资源,此时就唤醒一个等待进程。因此信号量实际是一个被保护的整型变量,只能通过PV进行操作,操作系统保证PV操作的原子性。通常假定信号量是公平的,线程不会无线阻塞在P操作,可以假定信号量等待时按照先进先出排队的。而自旋锁是无法实现先进先出的,因为它需要占用CPU资源不停查询锁是否空闲,无法指定进入临界区的顺序。

信号量的使用

      信号量可以分为两类:二进制信号量(资源数目为0或1)和资源信号量(资源数目可以为任何非负值)。两者其实是等价的,可以基于一个构造出另一个。信号量的使用有两种情况:互斥访问比如临界区的互斥访问控制、条件同步比如线程间的条件等待。互斥访问如下图

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值