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

来源:互联网 发布:大数据行业是干什么的 编辑:程序博客网 时间:2024/05/16 09:23

之前总结了和资源有关的银行家算法,随着学习的深入,对于资源的理解也有了更深的理解,此篇文章通过解决同步、异步问题的典型机制——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操作自己的理解还很肤浅,只是冰山一角,有待提高,望各位大神多多指教!

0 0
原创粉丝点击