码迷,mamicode.com
首页 > 其他好文 > 详细

PV操作——软考探究(五)

时间:2015-03-09 20:54:58      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:

    之前总结了和资源有关的银行家算法,随着学习的深入,对于资源的理解也有了更深的理解,此篇文章通过解决同步、异步问题的典型机制——PV操作来加深对资源的理解。

P操作:申请一个资源。它是执行操作的前提,只有有了资源才可以执行操作。就和现实生活是一样的,只有有了资源才能够进行生产。

V操作:释放一个资源。在执行完毕一个操作以后要将占用的资源释放掉,和银行家算法吻合, 同时发出信号。

】两个相关联的进程A和B,他们共享一个缓冲器。进程A不断地读入数据,并送入缓冲器;进程B不断地从缓冲器中取出数据并加工。所以这里两个进程就存在着制约关系,便可以通过PV操作来解决。

     技术分享

现声明两个信号S1、S2,分别表示进程A和进程B的两个状态,当进程A读入数据并送入缓冲器时,完成自己的读取工作,并发出信号提示进程B可以来缓冲器取数据;此时,进程B得到信号后,从缓冲器中取出数据加工完毕之后发出完毕信号提示进程A可以继续执行自己的工作,这便是他俩的工作制约关系。针对这一流程PV原语如下:

begin

  S1,S2:semaphore;

  S1:=1,S2:=1;    

  cobegin

  process P1

    begin

      L1:P(S1);

         V(S2);

         go to L1;

    end;

  process P2

    begin

      L2:P(S2);

         V(S1);

         go to L2;

    end;

  coend;

end; 

PV操作解决的问题:

1.顺利解决了同步进程的冲突问题;

2.实现了进程的同步和共享资源的互斥操作;

    当然,对于PV操作自己的理解还很肤浅,只是冰山一角,有待提高,望各位大神多多指教!

PV操作——软考探究(五)

标签:

原文地址:http://blog.csdn.net/u010508826/article/details/40748405

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!