`

PV操作

阅读更多

定义:

      在计算机操作系统中,PV操作是进程管理中的难点。

     首先应弄清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操作属于进程的低级通信。

什么是信号量?信号量(semaphore)的数据结构为一个值和一个指针,指针指向等待该信号量的下一个进程。信号量的值与相应资源的使用情况有关。当它的值大于0时,表示当前可用资源的数量;当它的值小于0时,其绝对值表示等待使用该资源的进程个数。注意,信号量的值仅能由PV操作来改变。

    一般来说,信号量S>=0时,S表示可用资源的数量。执行一次P操作意味着请求分配一个单位资源,因此S的值减1;当S<0时,表示已经没有可用资源,请求者必须等待别的进程释放该类资源,它才能运行下去。而执行一个V操作意味着释放一个单位资源,因此S的值加1;若S=<0,表示有某些进程正在等待该资源,因此要唤醒一个等待状态的进程,使之运行下去。

 

******************************************************************************************

 

同步、互斥:

同步:其实说同步还不如说”协作“,就是我们的目标只有一个,我们奔着同一个目标去的,都是在大家的努力下共同完成这么一件事情。还是比较容易理解的吧。不见得太难。

互斥:借用别人的一句话“千军万马过独木桥”,很通俗的一句话,就把咱们这个概念表达的淋漓尽致,就好比有一个大部队来到独木桥这,但是必须排好队,一个一个来;其实现实生活中,还有一个很好的例子可以说明这个互斥的概念,比如打印机,打印机这个工具就非常好的体现了互斥的概念,打印机一旦被别人占用了,那无乱你有多着急,都只能等着,对吧。

其实借用别人的话或者资料或者工具来让咱们的学习更加轻松,为咱们的学习加把油,何乐而不为呢?这就是我要说的“站在巨人的肩膀上”来看问题,许多问题就变得轻松起来;这是一种思想,旨在为咱们的学习加把油~这是题外话,但是更重要的是一种思想,很值得学习。

我们接下来还继续看一下一张同步的图:



 

这张图也特别的形象具体,我们具体来看看这张图,A仓库有货物,然后我们需要把货物搬运到B仓库,由搬运工甲和搬运工乙来完成这个过程;那么他们的目标就只有一个,就是把货物从A搬到B去,共同奔着这个方向去发展,所以我们说这是一个同步的问题。

 

临界资源:就是咱们刚刚说的互斥,诸进程间需要互斥方式对其进行共享资源,如打印机、光驱等。

临界区:就是进程访问临界资源的那段代码。

讲了那么久,我们才引入了PV操作,看来这个PV操作还是挺有意思的。

PV操作:解决互斥和同步的问题。PV操作是分开来看的:

P操作:使S=S-1,若S>=0,则该进程继续执行,否则该进程排入等待队列。

V操作:使S=S+1,若S>0,唤醒等待队列中的一个进程。

这样理解不太好理解,咱们还是来看例子吧:

接下来,我们来看一个与咱们生活很贴切的问题:生产者——消费者问题:

我们还是一样,通过图片来分析问题:



 

这是一个著名的同步问题,虽然生产者进程和消费者进程都是异步方式运行的,但它们之间必须保持同步,即不允许消费者进程到一个空缓冲区去取产品,也不允许生产者进程向一个已装满产品且尚未被取走的缓冲区中投放产品。这是一个单缓冲区情况。那么这个单缓冲区的PV操作,应该是怎样的呢?我们来看看:



 

我们分析分析,很容易的发现这个流程,前提是S1初值为1,S2初值为0。我们需要记住P操作减1,V操作加1,然后这个分析就变得易如反掌了,我们先对初值进行一下说明:

a、我们把S1的初值设为1:是说明缓冲区还有一个空间可以使用,对于生产者而言,每一个缓冲区的一个空间就是一个资源,也就是说,一开始运行的时候,就允许生产者投放一个产品到缓冲区,

b、然后投放到缓冲区之后,我们来看消费者进程,P(S2):首先我们要进程一个判断,判断缓冲区中是否有产品,对消费者而言,缓冲区中有产品,就代表有一个资源可以使用,但是最初状态那个缓冲区中是没有资源的,所以S2的初值应该是为0的。

我们刚才都提到了资源的问题,就是信号量的一个值应该是表示资源的数量,但是就消费者和生产者而言,对于他们的资源是不同的,概念是不同的,生产者:缓冲区有多少个空格,就有多少个资源;而对消费者来说,缓冲区有多少个满的格,就有多少个资源,是刚好是相反,所以说,就是这么相反,所以当消费者从缓冲区取出一个产品之后,对于生产者而已,就多了一个资源。

其实这个过程就是这样的。

1、生产者:P(S1),那么P(S1),S1=S1-1,得到P(S1=0)这个进程还能进行,那么生产者把一个产品投放到缓冲区。

2、V(S2),S2=S2+1,S2初值为0,所以S2=S2+1>0,那么就激活了P(S2),那么消费者就能取出一个产品。

4、消费产品:消费产品之前,还有一个V(S1),就激活了P(S1),让生产者继续投放产品到缓冲区。

特别简单吧,这是单缓冲区分析。

我们接下来看一个相对来说,有点复杂一点点的,多缓冲区的,其实也一样一样的,继续:

我们还是分析一样的问题,生产者、消费者问题:



 

对应的PV操作应该是这样的:



 

有一点区别,就是要引用互斥的概念,因为缓冲区是一个临界资源,它始终只能有一个进程对其进行操作,所以我们就可以用一个互斥信号量来完成这一点,所以当某一个进程要使用到缓冲区之前,我们就进行以下判断,判断这个缓冲区现在是不是空闲呢?是不是有生产者或者消费者的进程在使用这个这个缓冲区呢?如果有,mute的初值为1,当有人使用这个缓冲区的时候,这个mute的值就由1变为0,这时,第二个进程向再来操作这个缓冲区,就不可能了,就会被阻塞,当第一个进程使用完缓冲区

 

公交车司机与售票员的问题:



 

我们来分析这个过程,我们把S1=0和S2=1(s1是门的状态,只有门关了司机才能开车,s2是车的状态,只有车停了售票员才能开门。所以(s1=0,s2=1表示门开着,车停着))。我们来分析分析:

1、P(S1):S1=S1-1=0,那么司机进程就被暂停,等会售票员进程,售票员关车门。

2、V(S1):S1=S1+1=1,激活了司机进程,那么司机就开始启动车辆、正常行驶、到站停车,当然售票员也有可能同时在售票。

3、P(S2):S2=S2-1,售票员在售票之后的进程就被暂停,等待司机进程。这样就避免了售票员售票之后就开车门了。因为这是不允许的。

4、V(S2):S2=S2+1,司机到站停车之后,就激活了售票员P(S2)的进程,那么售票员就进程 开车门、上下客的操作。

那么这个进程就完成了。

  • 大小: 18.3 KB
  • 大小: 10.1 KB
  • 大小: 36.8 KB
  • 大小: 13.5 KB
  • 大小: 50.2 KB
  • 大小: 24 KB
分享到:
评论

相关推荐

    计算机操作系统中PV操作

    在计算机操作系统中,PV操作是进程管理中的难点,希望这点资料对你有帮助

    pv操作的实现

    操作系统中pv操作的c/c++的实现,主要是生产者-消费者问题的实例。

    计算机_操作系统_经典PV操作全集

    操作系统_经典PV操作全集

    操作系统PV操作

    操作系统的PV操作,由C语言实现。桌上有一盘子,可以存放一个水果。爸爸总是放苹果到盘子中,而妈妈总是放香蕉到盘子中;一个儿子专等吃盘中的香蕉,一个女儿专等吃盘中的苹果。用P,V操作实现上述问题的解。

    进程PV操作详细讲解

    进程PV操作详细讲解 PV操作 PV原语的含义  P操作和V操作是不可中断的程序段,称为原语。PV原语及信号量的概念都是由荷兰科学家E.W.Dijkstra提出的。信号量sem是一整数,sem大于等于零时代表可供并发进程使用的资源...

    pv操作和尚喝水问题

    和尚喝水问题 某寺庙,有小和尚、老和尚若干.庙内有一水缸,由小和尚提水入缸,供老和尚饮用。水缸可容纳 30 桶水,每次入水、取水仅为1...设水桶个数为5个,试用信号灯和PV操作给出老和尚和小和尚的活动。用C++实现

    pv操作实现前驱图

    pv操作实现前驱图

    操作系统课程设计PV操作

    操作系统课程设计,PV操作 操作系统课程设计PV操作 操作系统课程设计PV操作

    操作系统有关利用PV操作实现互斥与同步 ppt

    利用PV操作实现互斥与同步 有几个经典问题算法 1`哲学家围着一个圆桌在讨论问题和进餐 2南开大学和天津大学之间有一条弯曲的小路,其中从S到T有一段路每次只允许一辆自行车通过 3某数据库有一个写进程、多个读进程...

    操作系统课程设计——使用PV操作模拟实现车站大厅售票

    车站售票大厅有2个人工售票窗口,1个人工签票/...用信号量和PV操作写出顾客进程与人工服务进程的同步与互斥算法。 该压缩包内容为C++语言在VS2015下编写的工程文件,所有文件均在里面,解压后放到VS里即可调试运行。

    java模拟实现PV操作

    java模拟实现PV操作 利用线程的wait和notify方法实现PV操作实现生产者与消费者问题

    操作系统 有关PV操作 水果问题

    用VC实现的PV操作,能实现进程的互斥 桌上有一只盘子,每次只能放入一只水果;爸爸专向盘子中放苹果(apple),妈妈专向盘子中放桔于(orange),一个儿子专等吃盘子中的桔子,一个女儿专等吃盘子里的苹果

    操作系统 PV操作 实验报告

    一个能够完整运行出来的PV操作的实验报告,然后实验报告的结构也很完整,实验目的,实验过程,甚至实验的结果也有截图,如果有小伙伴需要,尽管下载哦

    pv操作解析 了解pv操作

    希望想了解的朋友多知道些 ,不为积分。pv操作的简洁性可以让你更好编程

    PV操作实现读者写者问题

    实现PV操作解决读者写者问题(读者优先)

    操作系统—经典PV操作详解

    操作系统—经典PV操作详解,针对PV操作的各个类型题目的经典讲解。

    模拟PV操作同步机构-消费者问题

    模拟PV操作同步机构,且用PV操作解决生产者——消费者问题

    操作系统pv操作讲解

    对操作系统的pv操作进行详细讲解 可对操作系统进行详细的了解

    C++ PV操作(生产者/消费者)简单实例

    自己写的PV操作简单实例,以简单易懂见长,如果您正在为此事发愁,也许它能帮到你。

    PV操作的实现(源代码+报告)

    本资源包括PV操作的源代码和报告,通过PV操作实现同步机制

Global site tag (gtag.js) - Google Analytics