信号量与PV操作
来源:互联网 发布:时间软件下载 编辑:程序博客网 时间:2024/06/05 04:26
1、信号量
信号量(semaphore)的数据结构为一个值和一个指针,指针指向等待该信号量的下一个进程。信号量的值与相应资源的使用情况有关。当它的值大于0时,表示当前可用资源的数量;当它的值小于0时,其绝对值表示等待使用该资源的进程个数。注意,信号量的值仅能由PV操作来改变。
信号量S表示了操作系统中资源与请求该资源进程的供求关系。
我们可以假设操作系统中某资源为某仓库的货物,而请求资源的的进程就是借用货物的消费者,当我们把货物(资源)尽可能地分配给消费者(进程)后,消费者使用过后要归还货物,以便之后的消费者借用。
当货物量多于消费者时,此时信号量为正数,表示剩余货物量;当消费者多于资源量时,此时信号量为负数(如-5),表示此时还有5个消费者等待货物。
2、PV操作
PV操作由P操作原语和V操作原语组成(原语是不可中断的过程),对信号量进行操作,具体定义如下:
P(S):①将信号量S的值减1,即S=S-1;
②如果S>0,则该进程继续执行;否则该进程置为等待状态,排入等待队列。
V(S):①将信号量S的值加1,即S=S+1;
②如果S>0,则该进程继续执行;否则释放队列中第一个等待信号量的进程。
PV操作的意义:我们用信号量及PV操作来实现进程的同步和互斥。PV操作属于进程的低级通信。
利用信号量和PV操作实现进程互斥的一般模型是:
进程P1 进程P2 …… 进程Pn
…… …… ……
P(S); P(S); P(S);
临界区; 临界区; 临界区;
V(S); V(S); V(S);
…… …… …… ……
3、使用PV操作实现进程互斥时应该注意的是:
(1)每个程序中用户实现互斥的P、V操作必须成对出现,先做P操作,进临界区,后做V操作,出临界区。若有多个分支,要认真检查其成对性。
(2)P、V操作应分别紧靠临界区的头尾部,临界区的代码应尽可能短,不能有死循环。
(3)互斥信号量的初值一般为1。
4、使用PV操作实现进程同步时应该注意的是:
(1)分析进程间的制约关系,确定信号量种类。在保持进程间有正确的同步关系情况下,哪个进程先执行,哪些进程后执行,彼此间通过什么资源(信号量)进行协调,从而明确要设置哪些信号量。
(2)信号量的初值与相应资源的数量有关,也与P、V操作在程序代码中出现的位置有关。
(3)同一信号量的P、V操作要成对出现,但它们分别在不同的进程代码中。
- 信号量与PV操作
- 信号量与PV操作
- 信号量与PV操作
- 信号量与PV操作
- 信号量与PV操作
- 信号量与PV操作
- 信号量与PV操作
- 信号量与PV操作
- 信号量与PV操作
- 信号量与PV操作
- 信号量与pv操作
- 信号量与PV操作
- 信号量与PV操作
- 信号量与PV操作
- 信号量与PV操作
- 信号量与PV操作
- PV操作与信号量
- 信号量与pv操作
- 换个格式输出整数
- 加法原理和乘法原理
- Kubernetes、Mesos和Swarm:Rancher编排引擎的比较
- 面向对象
- 动态无需加入执行路径的神器
- 信号量与PV操作
- 1001. 害死人不偿命的(3n+1)猜想 (15)
- [deeplearning-005] 一般形式的反向传导算法BP最简推导-3
- [Oracle 11g r2(11.2.0.4.0)]Oracle Golden Gate Training-workshop4
- Ubuntu开启telnet服务
- Maven核心概念学习
- 位运算符
- c++中纯虚函数与虚函数
- MySQL-python-1.2.4b4.win32-py2.7提示报错,无法安装的解决方案