4.5 同步和P-V操作

4.5.1 同步和互斥的概念

进程的互斥关系

例子

进程的互斥关系

  • 多个进程由于共享了独占性资源,必须协调个进程对资源的存取顺序:确保没有两个或以上的进程同时进行存取操作

  • 互斥和资源共享相关

  • 资源:临界资源

  • 存取操作区域:临界区

进程的同步关系

若干合作进程为了完成一个共同的任务,需要相互协调运行步伐,一个进程开始某个操作之前必须要求另一个进程已经完成某个操作,否则前面的进程只能等待。

进程同步的例子:司机和售票员

司机和售票员之间的操作属于同步关系

  • 司机:起步、行驶、停车
  • 售票员:关门、售票、开门

同步关系

  • 司机起步前售票员先关门,否则等待
  • 售票员开门前司机先停车,否则等待

进程同步关系——另一种解释

合作进程中某个操作之间需要满足某种先后关系或某个操作能否进行需要满足某个前提条件,否则只能等待

互斥关系属于特殊的同步关系

4.5.2 P-V操作概念

信号灯的概念

信号灯时一种卓有成效的进程同步机制

1965年荷兰学者Dijkstra提出

信号灯用于进程同步的基本思想

进程在运行过程中受信号灯状态控制,并能改变信号灯状态

  • 进程受控制:信号灯的状态可以阻塞或唤醒进程
  • 改变信号灯:信号灯的状态可以被进程改变

信号灯机制

数据结构

  • 信号灯变量定义为一个二元矢量\((S,q)\)
  • S:整数,处置非负(S又称信号量)
  • q:PCB队列,初值为空集
struct SEMAPHORE {
int S; //整数,初值非负
pointer_PCB q; //队列:进程PCB指针,初值空集
}

信号灯的操作

两个操作

  • P操作(函数或过程,P(S,q))
  • V操作(函数或过程,V(S,q))

P,V是荷兰语

  • Passeren通过
  • Vrijgeveb释放

P操作的原理(P(S,q)、P(S))

提示:P操作可能使得进程在调用处阻塞

提示2:S初值很重要

  • S的值减1
  • 若差大于或等于零,则进程继续
  • 若差小于零,则该进程阻塞并加入到队列q中,并转调度函数
P(S, q) {
S = S - 1;
if (S < 0) {
Insert(Caller, q);
Block(Caller);
转调度函数();
}
}

V操作的原理(V(S,q)、V(S))

提示:V操作可能会唤醒一个阻塞的进程

  • S值加1
  • 若和大于零,则该进程继续
  • 若和小于或等于零,则该进程继续同时从q中唤醒一个进程
V(S, q) {
S = S + 1;
if (S < 0) {
Remove(q, pid);
Wakeup(pid);
}
}

4.5.3 P-V操作解决互斥问题

实质是实现对临界区的互斥访问

允许最多一个进程处于临界区

应用过程

  • 进入临界区之前先执行P操作;(可能阻塞当前线程)
  • 离开临界区之后再执行V操作;(可能唤醒某个进程)

S的初值要设置合理

例子:3个进程Pa、Pb、Pc。CSa、CSb、CSc是临界区
Pa() {
P(mutex);
CSa
V(mutex);
}
Pb() {
P(mutex);
Csb
V(mutex);
}
Pc() {
P(mutex);
CSc
V(mutex);
} main() {
// 信号量mutex
int mutex = 1;
cobegin // 并发
Pa();
Pb();
Pc();
coend // 并发结束
}

4.5.4 P-V操作解决互斥问题

同步问题实质

  • 当运行条件不满足时,能让进程暂停

  • 运行条件满足时,能让进程立即继续

P-V操作应用于进程同步的基本思路

  • 暂停当前进程:在关键操作之前执行P操作

    • 必要时可暂停
  • 继续进程:在关键操作之后执行V操作
    • 必要时唤醒合作进程
  • 定义有意义的信号量S,并设置合适的初值
    • 信号量S能明确地表示“运行条件”

实现同步的例子:司机和售票员

司机:

  • 起步
  • 行驶
  • 停车

售票员

  • 关门
  • 售票
  • 开门

关键操作

  1. 一个操作的运行需要条件
  2. 一个操作的完成与否影响到另外一个操作能否运行

同步要求

  • 只有售票员关门后,司机才能起步
  • 只有在自己停车后,售票员才能关门
// 门是否关好?0:没有,1:关好
int S1 = 0;
// 车是否停稳?0:没有,1:停稳
int S2 = 0; // 司机进程
while (true) {
P(S1);
qibu();
xingshi();
tingche();
V(S2);
} // 售票员进程
while (true) {
guanmen();
V(S1);
shoupiao();
P(S2);
kaimen();
}

4.5.5 经典同步问题

经典同步问题1:生产者消费者问题

一群生产者(Producer)向一群消费者(Consumer)提供产品(数据),共享缓冲区

规则

  1. 不能向满缓冲区存产品
  2. 不能从空缓冲区取产品
  3. 每个时刻仅允许1个生产者或消费者存或取1个产品(互斥)
int empty = 5; // 信号量:缓冲区中空位的个数,初值5
int full = 0; // 信号量:缓冲区数据的个数,初值0
int mutex = 1; // 信号量:缓冲区互斥使用,初值1,可用 producer_i() {
while (TRUE) {
生产一个数据;
P(empty); // empty--
P(mutex);
存1个数据到缓冲区;
V(mutex);
V(full); // full++
}
} consumer_j() {
while (TRUE) {
P(full); // full--
P(mutex);
从缓冲区取1个数据;
消费/处理数据;
V(mutex);
V(empty); // empty++
}
}

4.5.6 读者和编者同步问题

问题描述:

有一本书

  • 有读者读书;有多个读者
  • 有编者编书;有多个编者

要求

  • 允许多个读者同时读
  • 不允许读者、编者同时操作
  • 不允许多个编者同时操作
/*
如何实现:
编者之间的互斥
编者和读者之间的互斥
读者之间不互斥
*/
int editor = 1; // 互斥量:编者对编者和读者的互斥
int ReadCount = 0; // 读者计数
int mutex = 1; // 互斥量:ReadCount时临界资源 Reader_i() {
while (true) {
P(mutex);
ReadCount++;
if (ReadCount == 1)
P(editor);
V(mutex);
读书;
P(mutex);
ReadCount--;
if (ReaderCount == 0)
V(editor);
V(mutex);
}
} Editor_i() {
while (true) {
P(editor);
编书;
V(editor);
}
}

小结

信号灯机制P-V操作解决同步问题

  • 区分关键操作或运行条件或影响
  • 关键操作之前P操作
  • 关键操作之后V操作

生产者—消费者问题

  • 同步和互斥混合

读者—写者问题

  • 互斥问题

【av68676164(p25-p30)】同步和P-V操作的更多相关文章

  1. P,V操作及同步互斥实例

    无论是计算机考研.计算机软件水平考试.计算机操作系统期末考试还是其他计算机岗位考试,P.V原语操作都是一个常考点.下面笔者总结了关于P.V操作的一些知识. 信号量是最早出现的用来解决进程同步与互斥问题 ...

  2. 操作系统中的P,V操作(转)

    无论是计算机考研.计算机软件水平考试.计算机操作系统期末考试还是其他计算机岗位考试,P.V原语操作都是一个常考点.下面笔者总结了关于P.V操作的一些知识. 信号量是最早出现的用来解决进程同步与互斥问题 ...

  3. P,V操作实例分析

    刚开始学习操作系统的时候,就听说PV操作,简单说说PV操作. ●  P(S): S=S-1 如果S≥0,则该进程继续执行:               S<0,进程暂停执行,放入信号量的等待队列 ...

  4. 关于P,V操作理解的分析

      P-V操作定义: 假设sem是个整型变量. P原语的主要操作是: (1)sem减1: (2)若sem减1后仍大于或等于零,则该进程继续执行: (3)若sem减1后小于零,则该进程被阻塞,在相应队列 ...

  5. P.V操作【转】

    阐述P,V原语的理论不得不提到的一个人便是赫赫有名的荷兰科学家 E.W.Dijkstra.如果你对这位科学家没有什么印象的话,提起解决图论中最短路径问题的Dijkstra算法应当是我们再熟悉不过的了. ...

  6. Linux-信号量与P,V操作

    Linux-信号量与P,V操作 内容 使用信号量实现进程互斥 使用信号量及PV实现子进程读写同步 机理 Linux信号量集 Linux信号量作为IPC机制的一种,与其他通信方式类似,Linux也是通过 ...

  7. 关于P,V操作理解的突破,关于并发设计与并行

    今天又找了一篇博客研究P,V操作.. 发现..它有一个变量没有声明.. 我就换了篇博客..http://c.biancheng.net/cpp/html/2600.html 然后就看懂了.. 关键突破 ...

  8. 另类P、V操作问题-详细图解

    问题模型 有一个系统,定义如下P.V操作: P(s): s.count--; then 将本进程插入相应队列末尾等待; V(s): s.count++; then 从相应等待队列队尾唤醒一个进程,将其 ...

  9. 进程理论 阻塞非阻塞 同步异步 I/O操作

    1.什么是进程 进程指的是一个正在运行的程序,进程是用来描述程序执行过程的虚拟概念 进程的概念起源于操作系统,进程是操作系统最核心的概念,操作系统其它所有的概念都是围绕进程来的 2.操作系统 操作系统 ...

  10. ftp客户端自动同步 Windows系统简单操作ftp客户端自动同步

    服务器管理工具它是一款功能强大的服务器集成管理器,包含win系统和linux系统的批量连接,vnc客户端,ftp客户端等等实用功能.我们可以使用这款软件的ftp客户端定时上传下载的功能来进实现ftp客 ...

随机推荐

  1. celery 基础教程(二):简单实例

    前言 使用celery包含三个方面:1. 定义任务函数.2. 运行celery服务.3. 客户应用程序的调用. 实例一: #1. 定义任务函数 创建一个文件 tasks.py输入下列代码: from ...

  2. GPO - AppLocker

    AppLocker can help you: Define rules based on file attributes that persist across app updates, such ...

  3. 关于Java8的精心总结

    前言 ​ 最近公司里比较新的项目里面,看到了很多关于java8新特性的用法,由于之前自己对java8的新特性不是很了解也没有去做深入研究,所以最近就系统的去学习了一下,然后总结了一篇文章第一时间和大家 ...

  4. 性能1.84倍于Ceph!网易数帆Curve分布式存储开源

    在上周刚结束的网易数字+大会上 网易数帆宣布: 开源一款名为Curve的高性能分布式存储系统, 性能可达Ceph的1.84倍! 网易副总裁.网易杭州研究院执行院长兼网易数帆总经理汪源: 基础软件的能力 ...

  5. JSON.stringify和JSON.parse的用法

    用法概述 所有的现代浏览器都支持 JSON 对象,有两个非常有用的方法来处理 JSON 格式的内容: JSON.parse(string) 接受一个 JSON 字符串并将其转换成一个 JavaScri ...

  6. 题解 洛谷 P6378 【[PA2010]Riddle】

    首先不难看出对于本题的点与点之间的限制关系,我们可以考虑用\(2-SAT\)来解决,通过从状态\(x\)向状态\(y\)连一条有向边表示若状态\(x\)存在,那么状态\(y\)必须存在. 接下来的处理 ...

  7. Jenkins怎么安装?Jenkins控制台输出乱码怎么处理?Jenkins执行selenium脚本时浏览器不显示怎么处理?

    今天我们来看一看Jenkins的安装. 首先我们看一下Jenkins是什么,能够干什么.Jenkins呢是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开 ...

  8. 前端学习(十一):CSS性质

    进击のpython ***** 前端学习--CSS性质 那在CSS上还有一些很重要的性质:继承性,层叠性以及特殊性 那本小节就基于这三个性质进行展开... ... 继承性 在CSS的某些样式是具有继承 ...

  9. Andriod开发---《横竖屏切换时 Activity的生命周期的总结》

    横屏切换竖屏Activity的生命周期详解,下面分析一下切换时具体的生命周期: 1.新建一个Activity,并把各个生命周期打印出来 2.运行Activity,得到如下信息 onCreate--&g ...

  10. python匿名函数和内置函数

    一.匿名函数 匿名函数定义lambda a,b,c:(x,y,z) a.b.c相当于形参,多个形参之间用逗号隔开,多个形参不能用括号括起来 (x.y.z)相当于返回值,多个返回值之间用逗号隔开,多个返 ...