本文主要是介绍PV 操作 ~~= = 转的很明显~,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
首先应弄清 PV操作的含义:PV操作由P操作原语和V操作原语组成(原语是不可中断的过程),对信号量进行操作,具体定义如下:
PV操作的意义 :我们用信号量及PV操作来实现进程的同步和互斥。PV操作属于进程的低级通信。
什么是信号量?信号量(semaphore)的数据结构为一个值和一个指针,指针指向等待该信号量的下一个进程。信号量的值与相应资源的使用情况有关。当它的值大于0时,表示当前可用资源的数量;当它的值小于0时,其绝对值表示等待使用该资源的进程个数。注意,信号量的值仅能由PV操作来改变。
进程P1
……
P(S);
临界区;
V(S);
……
PV操作是典型的同步机制之一。用一个信号量与一个消息联系起来,当信号量的值为0时,表示期望的消息尚未产生;当信号量的值非0时,表示期望的消息已经存在。用PV操作实现进程同步时,调用P操作测试消息是否到达,调用V操作发送消息。
【例1】生产者-消费者问题
在多道程序环境下,进程同步是一个十分重要又令人感兴趣的问题,而生产者-消费者问题是其中一个有代表性的进程同步问题。下面我们给出了各种情况下的生产者-消费者问题,深入地分析和透彻地理解这个例子,对于全面解决操作系统内的同步、互斥问题将有很大帮助。
(1)一个生产者,一个消费者,公用一个缓冲区。
定义两个同步信号量:
empty——表示缓冲区是否为空,初值为1。
生产者进程
while(TRUE){
生产一个产品;
}
消费者进程
while(True){
P(full);
(2)一个生产者,一个消费者,公用n个环形缓冲区。
定义两个同步信号量:
empty——表示缓冲区是否为空,初值为n。
full——表示缓冲区中是否为满,初值为0。
,指向下一个可用的缓冲区。
生产者进程
while(TRUE){
}
消费者进程
while(TRUE){
(3)一组生产者,一组消费者,公用n个环形缓冲区
定义四个信号量:
empty——表示缓冲区是否为空,初值为n。
full——表示缓冲区中是否为满,初值为0。
mutex1——生产者之间的互斥信号量,初值为1。
mutex2——消费者之间的互斥信号量,初值为1。
生产者进程
while(TRUE){
}
消费者进程
while(TRUE){
【例2】桌上有一空盘,允许存放一只水果。爸爸可向盘中放苹果,也可向盘中放桔子,儿子专等吃盘中的桔子,女儿专等吃盘中的苹果。规定当盘空时一次只能放一只水果供吃者取用,请用P、V原语实现爸爸、儿子、女儿三个并发进程的同步。
分析
int S=1;
int Sa=0;
int So=0;
}
思考题:
四个进程A、B、C、D都要读一个共享文件F,系统允许多个进程同时读文件F。但限制是进程A和进程C不能同时读文件F,进程B和进程D也不能同时读文件F。为了使这四个进程并发执行时能按系统要求使用文件,现用PV操作进行管理,请回答下面的问题:
(1)定义二个信号量S1、S2,初值均为1,即:S1=1,S2=1。其中进程A和C使用信号量S1,进程B和D使用信号量S2。
(2)从[1]到[8]分别为:P(S1) V(S1) P(S2) V(S2) P(S1) V(S1) P(S2) V(S2)
具体PV原语对信号量的操作可以分为三种情况:
1)
实现过程:
P(mutex);
访问该共享数据;
V(mutex);
非临界区
2)
实现过程:
P(resource);
使用该资源;
V(resource);
非临界区
3)
实现过程:
临界区C1;
V(S);
下面用几个例子来具体说明:
例1:某超市门口为顾客准备了100辆手推车,每位顾客在进去买东西时取一辆推车,在买完东西结完帐以后再把推车还回去。试用P、V操作正确实现顾客进程的同步互斥关系。
分析:把手推车视为某种资源,每个顾客为一个要互斥访问该资源的进程。因此这个例子为PV原语的第二种应用类型。
解:semaphore
void
{
}
例2:桌子上有一个水果盘,每一次可以往里面放入一个水果。爸爸专向盘子中放苹果,儿子专等吃盘子中的苹果。把爸爸、儿子看作二个进程,试用P、V操作使这四个进程能正确地并发执行。
分析:爸爸和儿子两个进程相互制约,爸爸进程执行完即往盘中放入苹果后,儿子进程才能执行即吃苹果。因此该问题为进程间的同步问题。
解:semaphore
semaphore
void
{
}
void
{
}
另附用PV原语解决进程同步与互斥问题的例子:
经典IPC问题如:生产者-消费者,读者-写者,哲学家就餐,睡着的理发师等可参考相关教材。
一、两个进程PA、PB通过两个FIFO(先进先出)缓冲区队列连接(如图)
PA |
PB |
Q1 |
Q2 |
解:// Q1队列当中的空闲缓冲区个数,初值为0
semaphore
// Q2队列当中的空闲缓冲区个数,初值为m
semaphore
// Q1队列当中的消息数量,初值为n
semaphore
// Q2队列当中的消息数量,初值为0
semaphore
void
{
}
void
{
}
二、《操作系统》课程的期末考试即将举行,假设把学生和监考老师都看作进程,学生有N人,教师1人。考场门口每次只能进出一个人,进考场的原则是先来先进。当N个学生都进入了考场后,教师才能发卷子。学生交卷后即可离开考场,而教师要等收上来全部卷子并封装卷子后才能离开考场。
(1)问共需设置几个进程?
(2)请用P、V操作解决上述问题中的同步和互斥关系。
解:semaphore
semaphore
semaphore
semaphore
int
semaphore
int
semaphore
void
{
P(S_Mutex2);
}
void
{
}
三、某商店有两种食品A和B,最大数量均为m个。
(1)
(2)
解:semaphore
semaphore
semaphore
semaphore
void
{
}
// “A食品加1,而B食品不变”这种情形允许出现的次数(许可证的数量),其值等于//k-(A-B),初值为k
semaphore
// “B食品加1,而A食品不变”这种情形允许出现的次数(许可证的数量),其值等于//k-(B-A),初值为k
semaphore
void
{
}
void
{
}
四:在一栋学生公寓里,只有一间浴室,而且这间浴室非常小,每一次只能容纳一个人。公寓里既住着男生也住着女生,他们不得不分享这间浴室。因此,楼长制定了以下的浴室使用规则:(1)每一次只能有一个人在使用;(2)女生的优先级要高于男生,即如果同时有男生和女生在等待使用浴室,则女生优先;(3)对于相同性别的人来说,采用先来先使用的原则。
假设:
(1)当一个男生想要使用浴室时,他会去执行一个函数boy_wants_to_use_bathroom,当他离开浴室时,也会去执行另外一个函数boy_leaves_bathroom;
(2)当一个女生想要使用浴室时,会去执行函数girl_wants_to_use_bathroom,当她离开时,
问题:请用信号量和P、V操作来实现这四个函数(初始状态:浴室是空的)。
解:信号量的定义:
semaphore
semaphore
semaphore
普通变量的定义:
int
int
int
void
{
}
void
{
}
void
{
}
void
{
}
这篇关于PV 操作 ~~= = 转的很明显~的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!