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. Istio安全-认证(istio 系列七)

    Istio安全-认证 目录 Istio安全-认证 认证策略 配置 自动mutual TLS 全局启用istio的mutual TLS STRIC模式 卸载 针对单个命名空间或负载启用mutual TL ...

  2. Python Ethical Hacking - Bypass HTTPS(1)

    HTTPS: Problem: Data in HTTP is sent as plain text. A MITM can read and edit requests and responses. ...

  3. RocketMQ在面试中那些常见问题及答案+汇总

    0.汇总 RocketMQ入门到入土(一)新手也能看懂的原理和实战! RocketMQ入门到入土(二)事务消息&顺序消息 从入门到入土(三)RocketMQ 怎么保证的消息不丢失? Rocke ...

  4. C++语法小记---经典问题之一(malloc和new的纠缠)

    malloc和new以及free和delete的区分 new和malloc以及delete和free的区别 new和delete是C++的关键字,malloc和free是库函数 new和delete会 ...

  5. [redis] -- 集群篇

    三种集群方式 主从同步:主从复制模式中包含一个主数据库实例(master)与一个或多个从数据库实例(slave) 优点: master能自动将数据同步到slave,可以进行读写分离,分担master的 ...

  6. 一个使用android相机的例子,二维码必须用相机

    https://blog.csdn.net/feiduclear_up/article/details/51968975

  7. OFD呼之欲来、来之跚跚,谁之罪?

    软件国产化的浪潮势不可挡,美国逼得逾甚,我们压迫感逾强,唯有奋起直追方慰平生之志. 在板式文档领域,pdf已成为国际标准,亦可称为美国标准:它在该领域一枝独秀,已形成一览众山小之势! pdf出道20余 ...

  8. Bug -- WebService报错(两个类具有相同的 XML 类型名称 "{http://webService.com/}getPriceResponse"。请使用 @XmlType.name 和 @XmlType.namespace 为类分配不同的名称。)

    调用WebService时报错 解决方法: 在提示的两个java文件中加如一行代码namespace = "http://namespace.thats.not.the.same.as.th ...

  9. defineProperty 和Proxy双向绑定演示,你还不知道么?

    双向绑定,也就是说js中的数据传到页面,页面中的内容到js,实现同步更新,简单的演示可以直接复制下放HTML代码运行. 在这个例子中,我们使用defineProperty ,Object.define ...

  10. Python 实现分层聚类算法

    ''' 1.将所有样本都看作各自一类 2.定义类间距离计算公式 3.选择距离最小的一堆元素合并成一个新的类 4.重新计算各类之间的距离并重复上面的步骤 5.直到所有的原始元素划分成指定数量的类 程序要 ...