PV操作

一、什么是PV操作?

PV操作由P操作原语和V操作原语组成(原语是不可中断的过程),对信号量进行操作,具体定义如下:

P(S):
①将信号量S的值减1,即S=S-1;
②如果S>0,则该进程继续执行;
如果s<=0,则进程进入等待状态,排入等待队列。

V(S):
①将信号量S的值加1,即S=S+1;

二、PV操作的意义:

我们用信号量及PV操作来实现进程的同步和互斥。PV操作属于进程的低级通信。

三、什么是信号量?

信号量(semaphore)的数据结构为一个值和一个指针,指针指向等待该信号量的下一个进程。
信号量的值与相应资源的使用情况有关:

①: 当信号量的值大于0时,表示当前可用资源的数量

②: 当它的值小于0时,其绝对值表示等待使用该资源的进程个数
注意,信号量的值仅能由PV操作来改变。

四、使用PV操作注意事项:

①: 每个程序中用户实现互斥的P、V操作必须成对出现,先做P操作,进临界区,后做V操作,出临界区。若有多个分支,要认真检查其成对性。

②: P、V操作应分别紧靠临界区的头尾部,临界区的代码应尽可能短,不能有死循环。

③: 互斥信号量的初值一般为1。

你可能感兴趣的:(java)