进程互斥和同步
实验、进程的同步与互斥——生产者消费者
实验、进程的同步与互斥——⽣产者消费者1. 1. 实验⽬的两个或两个以上的进程,不能同时进⼊关于同⼀组共享变量的临界区域,否则可能发⽣与时间有关的错误,这种现象被称作进程互斥。
对CPU的速度和数⽬不做出任何假设的前提下,并发进程互斥访问临界资源,是⼀个较好的解决⽅案。
另外,还需要解决异步环境下的进程同步问题。
所谓异步环境是指:相互合作的⼀组并发进程,其中每⼀个进程都以各⾃独⽴的、不可预知的速度向前推进;但它们⼜需要密切合作,以实现⼀个共同的任务,即彼此“知道”相互的存在和作⽤。
实验⽬的:分析进程争⽤资源的现象,学习解决进程同步与互斥的⽅法。
本实验属于设计型实验,实验者可根据⾃⾝情况选⽤合适的开发环境和程序架构。
1. 2. 实验原理信号量的PV操作与处理相关,P表⽰通过的意思,V表⽰释放的意思。
1962年,狄克斯特拉离开数学中⼼进⼊位于荷兰南部的艾恩德霍芬技术⼤学(Eindhoven Technical University)任数学教授。
在这⾥,他参加了X8计算机的开发,设计与实现了具有多道程序运⾏能⼒的操作系统——THE Multiprogramming System。
THE是艾恩德霍芬技术⼤学的荷兰⽂Tchnische Hoogeschool Eindhov –en的词头缩写。
狄克斯特拉在THE这个系统中所提出的⼀系统⽅法和技术奠定了计算机现代操作系统的基础,尤其是关于多层体系结构,顺序进程之间的同步和互斥机制这样⼀些重要的思想和概念都是狄克斯特拉在THE中⾸先提出并为以后的操作系统如UNIX等所采⽤的。
为了在单处理机的情况下确定进程(process)能否占有处理机,狄克斯特拉将每个进程分为“就绪”(ready)、“运⾏”(running)和“阻塞”(blocking)三个⼯作状态。
由于在任⼀时刻最多只有⼀个进程可以使⽤处理机,正占⽤着处理机的进程称为“运⾏”进程。
当某进程已具备了使⽤处理机的条件,⽽当前⼜没有处理机供其使⽤,则使该进程处于“就绪”状态。
进程同步和互斥的概念
进程同步和互斥的概念
进程同步和互斥是操作系统中的两个关键概念,它们用于控制多个进程并发执行时的互相干扰和冲突。
进程同步指的是多个进程在运行过程中需要相互协调和配合,以便达到某种预期的效果。
这种场景通常需要使用一些机制,如信号量、互斥锁、条件变量等来协调进程之间的执行顺序和同步过程。
互斥则是指多个进程之间的资源访问冲突问题。
在多进程并发执行的情况下,会存在多个进程同时访问同一个共享资源的情况,这样就有可能引发数据竞争和资源的访问冲突。
通过使用互斥信号量或者互斥锁等机制,可以有效地避免这种冲突的发生,保证每个进程对共享资源的访问互不干扰,从而实现进程之间的安全交互。
操作系统第6章 进程互斥与同步
Co-begin void Producer_i( ) (i=1,2…k) { item next_p; while(1){ produce an item in next_p P(empty); P(s); add next_p to buffer V(s); V(full); } } void consumer_j( ) (j=1,2…m) { item next_c; while(1){ P(full); P(s); remove an item from buffer to next_c V(s); V(empty); consume the item in next_c}} Co-end
• 进入临界段之前要申请,获得批准方可进入; • 退出临界段之后要声明,以便其他进程进入。
用程序描述: While(1){ entry_section; critical_section; exit_section; remainder_section; }
解决临界段问题的软件算法必须遵循:
准则1:不能虚设硬件指令或假设处理机数目。 准则2:不能假设n个进程的相对速度。 准则3:当一个进程未处于其临界段时,不应阻止 其他进程进入临界段。 准则4:当若干进程欲进入临界段时,应在有限时 间内选出一个进程进入其临界段。 用准则3,4不难推出下面原则 协调各进程入临界段的调度原则: • 当无进程处于临界段时,允许一个进程立即进入临界段。
3.实现临界段的硬件方法
利用处理机提供的特殊指令实现临界区加锁。 常见硬件指令有: ⑴ “Test_and_Set”指令 该指令功能描述为: int *target ( 限定为0,1) int Test_and_Set (int *target) { int temp; temp = *target ; *target = 1; return temp; }
进程间同步的几种方法
进程间同步的几种方法进程间同步是指两个或多个进程之间进行协调,以确保它们能够正确地执行。
这是多任务操作系统中的重要问题,因为进程之间共享资源,包括内存、文件和网络连接等。
进程同步的关键是确保一组进程在处理共享资源时,能够避免发生竞态条件(Race Condition)和死锁(Deadlock)。
竞态条件指多个进程同时访问共享资源,导致不正确的结果。
死锁指多个进程互相等待,导致它们都无法继续执行。
1. 互斥锁互斥锁是最常见的同步方法之一,它被用来保护共享资源,确保同一时刻只有一个进程可以访问它。
当一个进程获取了锁,其他进程必须等待,直到锁被释放。
在 POSIX 系统中,互斥锁可以通过 pthread_mutex_t 数据类型实现。
我们可以使用pthread_mutex_init() 函数初始化锁,使用 pthread_mutex_lock() 函数获取锁,使用pthread_mutex_unlock() 函数释放锁。
下面是一个例子,展示了如何使用互斥锁同步两个进程对共享变量的访问:```c#include <pthread.h>#include <stdio.h>int count = 0;pthread_mutex_t lock;void *increment(void *arg) {for (int i = 0; i < 1000000; i++) {pthread_mutex_lock(&lock); // 获取锁count++;pthread_mutex_unlock(&lock); // 释放锁}return NULL;}在上面的例子中,我们创建了两个线程,它们分别对共享变量 count 进行了一百万次的递增操作。
我们使用了互斥锁来保护 count 变量,确保同一时刻只有一个线程可以访问它。
2. 信号量3. 条件变量条件变量可以被用来支持更高级的同步机制,如互斥锁和信号量。
linux进程间同步机制
linux进程间同步机制一、进程间同步的概念在多进程系统中,进程间的通信是必要的,但同时也要防止进程间的相互干扰和数据污染。
进程间的同步机制就是用于解决这一问题的机制,它通过控制进程间的执行顺序、共享资源访问等方式,确保进程间的正确协作。
1. 互斥锁(Mutex)互斥锁是一种常用的进程同步机制,用于保护共享资源,防止多个进程同时访问和修改共享资源,导致数据错误或不一致。
使用互斥锁时,进程需要先获取锁才能访问共享资源,释放锁后才能进行其他操作。
示例代码:```cpthread_mutex_t mutex;pthread_mutex_lock(&mutex);// 访问共享资源pthread_mutex_unlock(&mutex);```2. 信号量(Semaphore)信号量是一种计数器,用于控制对共享资源的访问。
它可以实现进程间的同步和互斥,确保在任何时刻只有一个进程可以访问共享资源。
示例代码:```c#define MAX_COUNT 5sem_t sem;sem_wait(&sem); // 等待信号量释放// 访问共享资源sem_post(&sem); // 释放信号量```3. 屏障(Barrier)屏障是一种用于同步进程的机制,用于确保所有进程在执行完一定操作后才能继续执行。
在多线程或多进程编程中,屏障可以用于确保所有线程或进程完成了某个阶段的准备工作后,再继续执行后续的操作。
示例代码:```cpthread_barrier_t barrier;pthread_barrier_wait(&barrier); // 等待所有线程或进程到达屏障位置```4. 管道(Pipe)和消息队列(Message Queue)管道和消息队列是用于进程间通信的机制,它们允许一个进程向另一个进程发送消息或数据。
通过管道和消息队列,进程间可以异步地交换数据,从而实现同步。
第4章 进程的同步与互斥
mxh
同步
生产者活动:
Repeat 加工一件物品
消费者活动:
Repeat wait(full)
wait(empty)
物品放入箱中 signal(full)
箱中取一物品
signal(empty) 消耗这件物品
Until false
Until false
mxh
互斥
生产者活动:
Repeat
认为缓冲区同一时刻只有一个人可
mxh
4.1 进程的同步和互斥
信号量定义(记录型信号量)
semaphore是一个结构体: typedef struct {
int value;
//资源的个数
//进程链表
struct process *L;
} semaphore;
mxh
4.1 进程的同步和互斥 申请一个
• 信号量操作wait现在可按如 下来定义: void wait (semaphore S) { S.value - -; if (S.value <0) { add this process to S.L; block(); } }
mxh
4.1 进程的同步和互斥
• 信号量的应用
–合作进程的执行次序 –共享缓冲区的进程的同步
mxh
4.1 进程的同步和互斥
• 合作进程的执行次序:
–保证一组合作进程按照逻辑需要所确定 的次序进行。
mxh
4.1 进程的同步和互斥
• 合作进程的执行次序
–可以用一个图来表示进程集合的执行次 序。图的连接描述了进程开始和结束的 次序约束,此图称为进程流图. –例如P78,图4-2。 –使用信号量机制实现图4-2的同步。(练 习)
详解进程同步与互斥机制
详解进程同步与互斥机制⽬录⼀、什么是进程同步⼆、什么是进程互斥三、常见的进程同步与互斥机制⼀、什么是进程同步在多道批处理系统中,多个进程是可以并发执⾏的,但由于系统的资源有限,进程的执⾏不是⼀贯到底的,⽽是⾛⾛停停,以不可预知的速度向前推进,这就是进程的异步性。
那么,进程的异步性会带来什么问题呢?举个例⼦,如果有 A、B 两个进程分别负责读和写数据的操作,这两个线程是相互合作、相互依赖的。
那么写数据应该发⽣在读数据之前。
⽽实际上,由于异步性的存在,可能会发⽣先读后写的情况,⽽此时由于缓冲区还没有被写⼊数据,读进程 A 没有数据可读,因此读进程 A 被阻塞。
进程同步(synchronization)就是⽤来解决这个问题的。
从上⾯的例⼦我们能看出,⼀个进程的执⾏可能影响到另⼀个进程的执⾏,所谓进程同步就是指协调这些完成某个共同任务的并发线程,在某些位置上指定线程的先后执⾏次序、传递信号或消息。
再举个⽣活中的进程同步的例⼦,你想要喝热⽔,于是你打了⼀壶⽔开始烧,在这壶⽔烧开之前,你只能⼀直等着,⽔烧开之后⽔壶⾃然会发⽣响声提醒你来喝⽔,于是你就可以喝⽔了。
就是说⽔烧开这个事情必须发⽣在你喝⽔之前。
注意不要把进程同步和进程调度搞混了:进程调度是为了最⼤程度的利⽤ CPU 资源,选⽤合适的算法调度就绪队列中的进程。
进程同步是为了协调⼀些进程以完成某个任务,⽐如读和写,你肯定先写后读,不能先读后写吧,这就是进程同步做的事情了,指定这些进程的先后执⾏次序使得某个任务能够顺利完成。
⼆、什么是进程互斥同样的,也是因为进程的并发性,并发执⾏的线程不可避免地需要共享⼀些系统资源,⽐如内存、打印机、摄像头等。
举个例⼦:我们去学校打印店打印论⽂,你按下了 WPS 的 “打印” 选项,于是打印机开始⼯作。
你的论⽂打印到⼀半时,另⼀位同学按下了 Word 的 “打印” 按钮,开始打印他⾃⼰的论⽂。
想象⼀下如果两个进程可以随意的、并发的共享打印机资源,会发⽣什么情况?显然,两个进程并发运⾏,导致打印机设备交替的收到 WPS 和 Word 两个进程发来的打印请求,结果两篇论⽂的内容混杂在⼀起了。
计算机操作系统-陆丽娜-课后答案第四章
14. 设 N 为整型数,初始值为 3,两个并发进程 A 和 B 的程序如下:
process A
process B
do{ N=N+5; }
do{ print(N);
N=0;
} 若 process A 先执行了三个循环后,process A 和 process B 又并发执
行了一个循环,写出可能出现的打印值。请用 P、V 操作实现同步, 使两并发进程能正确执行。
量 S1 和 S2 初值均为 0。试问 P1、P2 并发执行后,x、y 的值各为多 少?
P1:
P2:
begin
begin
y:=1;
x:=1;
y:=y+3;
x:=x+5;
V(S1);
P(S1);
z:=y+1;
x:=x+y;
P(S2);
V(S2);
y:=z+y
end
z:=z+x;
end 答:x=10 y=9 z=15
9. 列举死锁的各种预防策略。 答: 静态分配资源策略:要求每一个进程在开始执行前就要申请它所需要 的全部资源,仅当系统能满足进程的资源申请要求时才把资源分配给 进程,该进程才能开始执行(注意,所有并发执行的进程要求的资源 总和不能超过系统拥有的资源数)。(破坏第二个条件)
按序分配资源策略:把系统中所有资源排一个顺序,对每一个资源给 一个确定的编号,规定任何一个进程申请两个以上资源时总是先申请 编号小的资源,后申请编号大的资源(或者先申请编号大的,后申请 编号小的资源)。系统按进程对资源的申请顺序来分配资源。按序分 配策略将阻止死锁 的第四个条件(循环等待条件)的出现。
end
Ⅱ 单项选择题
进程同步问题总结
进程同步问题总结进程同步问题主要涉及到并发进程之间的协作和同步,以实现多进程的协同工作。
以下是进程同步问题的主要总结:1.进程同步的概念:进程同步是一种协调多个进程运行顺序的机制。
它使得进程能够在正确的时间点上,按照一定的顺序进行交互和协作。
2.进程同步的必要性:在多进程环境中,如果不同进程的执行顺序不协调,就可能导致数据不一致、竞争条件等问题。
进程同步可以解决这些问题,保证多进程环境下的正确性和可靠性。
3.进程同步的主要方法:a) 信号量(Semaphore):信号量是一种计数器,用于控制多个进程对共享资源的访问。
信号量的值表示当前可用的共享资源数量。
通过设置信号量的初始值和使用P、V操作(或称为wait和post操作),可以实现进程的同步和互斥。
b) 互斥锁(Mutex):互斥锁是一种同步机制,用于防止多个进程同时访问共享资源。
当一个进程获得锁时,其他进程将被阻塞,直到锁被释放。
c) 条件变量(Condition):条件变量用于实现进程间的条件等待。
当一个进程需要等待某个条件成立时,它会使用条件变量的wait操作阻塞自己。
当另一个进程改变了条件并通知等待的进程时,被阻塞的进程将被唤醒。
d) 事件(Event):事件是一种同步机制,用于通知其他进程某个事件已经发生。
事件通常分为信号事件和广播事件。
信号事件只通知一个进程,而广播事件通知所有等待该事件的进程。
4.死锁问题:在进程同步过程中,如果多个进程互相等待对方释放资源,就会产生死锁问题。
避免死锁的方法包括:避免循环等待、按顺序申请资源、设置超时时间等。
5.进程同步的应用:进程同步广泛应用于操作系统、并发程序设计、网络通信等领域。
例如,在操作系统中,进程同步可以用于实现进程调度、任务管理、文件系统等重要功能。
在并发程序设计中,进程同步可以用于实现多线程的协同工作、数据访问控制等功能。
在网络通信中,进程同步可以用于实现数据传输、远程过程调用等功能。
电大操作系统 第2章教材习题解答
第2章进程管理“练习与思考”解答1.基本概念和术语进程、进程互斥、进程同步、临界资源、临界区、死锁进程是程序在并发环境中的执行过程。
进程互斥:各个进程彼此不知道对方的存在,逻辑上没有关系,由于竞争同一资源(如打印机、文件等)而发生相互制约。
进程同步:各个进程不知对方的名字,但通过对某些对象(如I/O缓冲区)的共同存取来协同完成一项任务。
临界资源:一次仅允许一个进程使用的资源。
临界区:在每个进程中访问临界资源的那段程序。
死锁是指在一个进程集合中的每个进程都在等待仅由该集合中的另一个进程才能引发的事件而无限期地僵持下去的局面。
2.基本原理和技术(1)在操作系统中为什么要引入进程概念?它与程序的区别和联系是什么?在操作系统中,由于多道程序并发执行时共享系统资源,共同决定这些资源的状态,因此系统中各程序在执行过程中就出现了相互制约的新关系,程序的执行出现“走走停停”的新状态。
这些都是在程序的动态过程中发生的。
用程序这个静态概念已不能如实反映程序并发执行过程中的这些特征。
为此,人们引入“进程”这一概念来描述程序动态执行过程的性质。
进程与程序的主要区别是:·进程是动态的;程序是静态的。
·进程有独立性,能并发执行;程序不能并发执行。
·二者无一一对应关系。
·进程异步运行,会相互制约;程序不具备此特征。
但进程与程序又有密切的联系:进程不能脱离具体程序而虚设,程序规定了相应进程所要完成的动作。
(2)进程的基本状态有哪几种?通常在操作系统中,进程至少要有三种基本状态。
这三种基本状态是:运行态、就绪态和阻塞态(或等待态)。
(3)用如图3-23所示的进程状态转换图能够说明有关处理机管理的大量内容。
试回答:①什么事件引起每次显著的状态变迁?②下述状态变迁因果关系能否发生?为什么?(A)2→1 (B)3→2 (C)4→1图3-23 进程状态转换图①就绪→运行:CPU空闲,就绪态进程被调度程序选中。
进程同步与互斥课程设计
进程同步与互斥课程设计一、课程目标知识目标:1. 理解进程同步与互斥的概念,掌握其基本原理;2. 学会使用同步互斥机制解决实际问题,了解其在操作系统中的应用;3. 掌握进程同步互斥的常用算法,如信号量、管程等;4. 了解进程死锁与饥饿的概念,分析其产生原因及解决方法。
技能目标:1. 能够运用同步互斥机制设计简单的并发程序;2. 能够分析并解决进程同步互斥中的问题,如死锁、饥饿等;3. 能够运用所学知识,对实际操作系统中的同步互斥问题进行优化。
情感态度价值观目标:1. 培养学生对操作系统学科的兴趣,激发其学习热情;2. 培养学生的团队协作意识,学会与他人共同分析、解决问题;3. 培养学生的创新思维,敢于尝试解决实际问题;4. 培养学生严谨的科学态度,注重理论与实践相结合。
课程性质:本课程为计算机科学与技术专业高年级学生的专业核心课程,旨在使学生掌握操作系统中的进程同步与互斥知识,具备实际应用能力。
学生特点:学生已具备一定的编程基础和操作系统基本知识,具备分析问题的能力,但可能对进程同步互斥的理解不够深入。
教学要求:结合学生特点,采用案例教学、分组讨论等方式,注重理论与实践相结合,提高学生的实际应用能力。
通过本课程的学习,使学生能够更好地理解和掌握进程同步与互斥知识,为后续课程和实际工作打下坚实基础。
二、教学内容1. 进程同步与互斥基本概念:包括进程同步的定义、互斥的概念及其重要性;2. 同步互斥机制:信号量、管程的原理与实现,以及其在并发程序中的应用;3. 死锁与饥饿问题:死锁的定义、产生原因、预防与避免策略,饥饿现象及其解决方案;4. 同步互斥算法实例分析:分析经典同步互斥算法,如生产者-消费者问题、读者-写者问题等;5. 操作系统中的应用:结合实际操作系统,分析同步互斥机制在文件系统、进程管理等方面的应用;6. 进程同步互斥编程实践:设计并发程序,运用同步互斥机制解决实际问题。
教学内容安排与进度:第1周:进程同步与互斥基本概念;第2周:同步互斥机制(信号量、管程);第3周:死锁与饥饿问题;第4周:同步互斥算法实例分析;第5周:操作系统中的应用;第6周:进程同步互斥编程实践。
进程互斥和同步举例
4.4.5.1 UNIX的信号量 4.4.5.2 Windows NT
4.4.5.1 UNIX的信号量
• 支持信号量和信号量集,通过semaphore ID来标识 • 有关的系统调用:
– 获取信号量集semget(依据用户给出的整数 值key,创建新信号量或打开现有信号量, 返回一个信号量ID) – 信号量控制操作semctl(查询信号量状态等) – semop(对信号量的原子操作)
– InterlockedExchange进行32位数据的先读后写原子 操作; – InterlockedCompareExchange依据比较结果进行赋值 的原子操作; – InterlockedExchangeAdd先加后存结果的原子操作; – InterlockedDecrement先减1后存结果的原子操作; – InterlockedIncrement先加1后存结果的原子操作;
• 间接通信:借助于收发双方进程之外的共享数 据结构作为通信中转,如消息队列。通常收方 和发方的数目可以是任意的。
3. 高级通信的特征
• 通信链路(communication link):
– 点对点/多点/广播 – 单向/双向 – 有容量(链路带缓冲区)/无容量(发送方和接收方需自备缓冲区)
• 数据格式:
– CreateSemaphore创建一个信号量对象,指定最大 值和初值,返回对象句柄; – OpenSemaphore返回一个已存在的信号量对象的 句柄,用于后续访问; – ReleaseSemaphore释放对信号量对象的占用;
实例:http://www.tol.oulu.fi/~avesanen/Rinn_Ohjelm/Harjoitukset/H8/Ratkaisut/SemaCon.cpp /~wild/windowsNT/Spring99/process.htm
操作系统 进程管理三互斥和同步二
while TS(&lock); critical section lock = FALSE; remainder section
• 利用TS实现进程互斥:每个临界资源设置一个 公共布尔变量lock,初值为FALSE • 在进入区利用TS进行检查:有进程在临界区时, 重复检查;直到其它进程退出时,检查通过;
Test-and-Set指令
该指令读出标志后设置为TRUE boolean TS(boolean *lock) { boolean old; old = *lock; *lock = TRUE; return old; } lock表示资源的两种状态:TRUE表示正被占用, FALSE表示空闲
6
互斥算法(TS指令)
记录型信号量和wait、signal原语
• 信号量是一个确定的二元组(value, L), value 是一个具有非负初值的整型变量,L 是 一个初始状态为空的队列。 • value代表资源的实体。在实际应用中应准确地说
明s的意义和初值;
– 初始化指定一个非负整数值,表示空闲资源总数(又称为―资源信号 量‖)--若为非负值表示当前的空闲资源数,若为负值其绝对值表示 当前等待临界区的进程数
第n个缓冲区
•Empty:有多少空缓冲区,初值为n; •Full:有多少带数据的缓冲区,初值 为0
B[n-1]
生产者消费者问题(续4)
4 用信号量实现进程的同步--生产者-消费者问题
• 我们把上面的例子扩 充,假定缓冲区 buffer 是 一 个 有 界 缓 冲 区, 可存放 n 个数据,同时 假 定 有 n 个 CP 进 程 不 断地产生数据,并送 buffer ; 有 m 个 IOP 进 程 从缓 冲区 中 取数 据 打印。 • 在我们生活中有很多 这样的例子。
进程同步与互斥问题
p1() {
while(1) {
洗桔子; P(m1) ; 放桔子; V(m3) ; } }
p2() {
while(1) {
洗苹果 ; P(m1); 放苹果; V(m2); } }
p3() {
while(1) {
P(m2) ; 取苹果; V(m1); 吃苹果;
} }
p4() {
while(1) {
P(m3) ; 取桔子; V(m1); 吃桔子;
p3() {
while(1) {
P(m2) ; 取水果; V(m1); 吃水果;
} }
进程的同步
分析:父母亲先放水果,儿子再取水果吃;父亲与儿子,母 亲与儿子是一个同步关系,父亲与母亲要竞争空盘子。
解法二:设信号量m1表示父亲或母亲放完水果,信号量m2 表示儿子取完水果。
int m1=0,m2=1; cobegin
放水果; }
吃桔子; }
吃苹果; }
进程的同步
分析:父亲先放水果,儿子女儿再吃水果;儿子女儿取完水 果,父亲再放水果,这三个进程是一个同步关系。
解法一:设信号量m1表示父亲能否放水果,m2表示儿子能 否取桔子,m3表示女儿能否取苹果。
int m1=1,m2=0,m3=0;
cobegin
p1() // p2() // p3()
} }
例3-4:吃水果。 父亲 母亲
进程的同步
女儿 桔 苹0子 果
儿子
父亲 P1 while(true) {
洗桔子;
母亲 P2 while (true) {
洗苹果;
放桔子; }
放苹果; }
儿子 P3 while(true) {
取苹果;
《进程同步与互斥》课件
消息传递的方式
包括发送和接收消息,以 及处理消息队列。
消息传递的作用
通过发送和接收消息,进 程可以交换信息,协调彼 此的行为,实现进程同步 。
共享内存机制
共享内存定义
多个进程共享同一块内存区域,通过 该区域进行通信。
共享内存的访问规则
共享内存的作用
通过共享内存,进程可以直接读写共 享数据,实现快速的数据交换和同步 。
学家都能进餐。这需要使用同步和互斥机制来控制哲学家进程的执行顺序。
05
进程同步与互斥的案例分析
基于信号量的进程同步案例
总结词
通过使用信号量作为同步机制,实现多个进程对 共享资源的正确访问。
总结词
通过使用信号量来控制进程的执行顺序,保证某 些进程必须先于其他进程执行。
详细描述
一个经典案例是生产者-消费者问题,其中生产者 和消费者共享一个有限的缓冲区。使用信号量来 控制生产者和消费者对缓冲区的访问,确保不会 发生溢出或饥饿现象。
哲学家就餐问题
总结词
哲学家就餐问题是进程同步与互斥问题中的一种经典问题,涉及到五个哲学家围坐在圆 桌旁,思考和进餐的哲学行为。
详细描述
哲学家就餐问题描述了一个场景,其中五个哲学家围坐在圆桌旁,他们有时思考,有时 进餐。餐桌中央有一盘意大利面,每位哲学家之间有一只叉子。如果一个哲学家要进餐 ,他需要同时拿起左右两只叉子。为了防止产生死锁,需要设计一种策略来确保所有哲
读者写者问题
总结词
读者写者问题是另一个经典的进程同步与互 斥问题,涉及到多个读者进程和写者进程对 共享资源的访问。
详细描述
读者写者问题描述了一个场景,其中多个读 者进程可以同时访问共享资源,但写者进程 在修改共享资源时需要独占式的访问。为了 维护数据的一致性和完整性,需要使用同步 和互斥机制来控制读者和写者进程的访问顺 序。
信号量实现进程互斥、同步、前驱关系
信号量实现进程互斥、同步、前驱关系信号量的值=这种资源的剩余数量(如果信号量的值⼩于0,说明此时有进程在等待这种资源)P(s)——申请⼀个资源,如果资源不够就阻塞等待V(S)——释放⼀个资源S,如果有进程在等待该资源,则唤醒⼀个进程。
1,信号量机制实现进程互斥(1)分析并发进程的关键活动,划定临界区(如:对临界资源打印机的访问就应放在临界区)(2)设置互斥信号量mutex,初值为1(3)在进⼊区P(mutex)——申请资源(4)在退出区V(mutex)——释放资源注意:对不同的临界资源需要设置不同的互斥信号量,p ,v操作必须成对出现。
缺少P(mutex)就不能保证临界资源的互斥访问,缺少V(mutex)会导致资源永不被释放,等待进程永不被唤醒。
/*记录型信号量的定义*/typedef struct{int value;struct process *L;}semaphore;/*信号量机制实现互斥*/semaphore mutex=1;p1(){...p(mutex);临界区代码...v(mutex);...}p2(){...p(mutex);临界区代码...v(mutex);...} 2,信号量实现进程同步进程同步:要让个并发进程按要求有序地推进。
p1(){代码1;代码2;代码3;}p2(){代码4;代码5;代码6;} ⽐如,p1,p2并发执⾏,由于存在异步性,因此⼆者交替推进的次序是不确定的。
若p2的代码4要基于p1的代码1和代码2的运⾏结果才能执⾏,那么我们就必须保证代码4⼀定是在代码2 之后才会执⾏。
这就是进程同步问题,让本来异步并发的进程互相配合,有序推进。
⽤信号量实现进程同步:(1)分析什么地⽅需要实现“同步关系”,即必须保证“⼀前⼀后”执⾏的两个操作(或两句代码)(2)设置同步信号量S,初始为0(3)在“前操作”之后执⾏V(S)(4)在后操作之前执⾏P(s)/*信号量机制实现同步*/semaphore S=0;//初始化同步信号量,初始值为0P1(){ P2(){代码1; P(s);代码2;代码4;V(s);//释放资源代码5;代码3;代码6;} } 若先执⾏到V(s)操作,则S++后S=1.之后当执⾏到P(s)操作时,由于s=1,表⽰有可⽤资源,会执⾏S--,S的值变回0,P2进程不会执⾏block原语,⽽是继续往下执⾏代码4.若先执⾏到P(s)操作,由于S=0,S--后S=-1,表⽰此时没有可⽤资源,因此P操作中会执⾏block原语,主动请求阻塞。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
交叉执行的现象。由共享公有资源而造成的对并发 进程执行速度的间接制约 2 直接制约关系(进程同步)
由于并发进程互相共享对方的私有资源所引起的 直接制约。
临界资源
象打印机这类资源一次只允许一个进程使用的 资源称为临界资源。属于临界资源有硬件打印 机、磁带机等,软件有消息缓冲队列、变量、 数组、缓冲区等。当然还有一类象磁盘等资源, 它允许进程间共享,即可交替使用,所以它称 为共享资源,而临界资源又称独享资源。
……; //P0的临界区代码
flag[ 1 ] =0;
//声明退出临界区
…….; // P1的非临界区代码
}
}
Coend
互斥-硬件支持1-禁止中断
提高临界区代码执行中断优先级
– 这种方法在UNIX和Windows NT中都使用,它是在 单机系统中有效地实现互斥的一种方法。
– 因为在传统操作系统中,打断进程对临界区代码的 执行只有中断请求、中断被接受后,系统有可能还 调用其它进程进入临界区,并修改此全局数据库。 所以用提高临界区中断优先级方法就可以屏蔽了其 它中断,保证了临界段的执行不被打断,从而实现 了互斥。
第三章 进程互斥与同步
主要内容
进程的同步和互斥机制的主要任务:控制并发 执行的诸进程之间能有效地共享和相互协作, 同时使并发执行的程序仍具有可再现性。
进程互斥 进程同步 利用信号量机制解决具体问题
进程间的关系
并发系统中诸进程由于资源共享、进程合作, 而产生进程之间的相互制约;又因共享资源的 方式不同,而导致两种不同的制约关系:
void Pi( void )
{
while (1) {
while( Test_and_Set( lock))
;
.....;
//Pi 临界区代码
lock = 0; //退出临界区
.....;
//Pi 非临界区代码
}
}
互斥-硬件支持2-特殊机器指令
2 swap 处理机指令,语义如下: void swap(int a, int b) {
flag[0] = 0;
…….; // P0的非临界区代码
}
}
void P1(void)
{
while( 1 ) {
while ( flag[0] == 1) ;
flag[1] = 1;
……; // P1的临界区代码
flag[1] = 0;
…….; // P1的非临界区代码
}
}
Coend
互斥-软件的忙等待方法-2
Test-and-Set的语义
int Test_and_Set( int target ) {
int temp; temp = target; target = 1; return temp; }
Test-and-Set 的应用
//lock为被测试变量,初值为0,互斥进程Pi(i=1,2...n)调用TS
}
}
void P1(void)
{
while( 1 ) {
while ( turn != 1 ) ;
……; // P1的临界区代码
turn = 0;
…….; // P1的非临界区代码
}
}
Coend
互斥-软件的忙等待方法-3
Peterson 1981 为了防止二进程为进入临界区而无限期等待,
又设置变量turn,表示不允许进入临界区的编号, 每个进程在先设置自己标志后再设置turn标志, 不允许另一个进程进入,这时再同时检测另一 个进程状态标志和不允许进入标志,这样可以 保证当二个进程同时要求进入临界区时,只允 许一个进程进入临界区。 仅适用于两个进程互斥
int temp; temp = a; a = b; b = temp; }
Swap 的应用
//lock为公用变量,初值为0(表临界资源空闲)
//keyi为进程Pi的对应变量,初值为0表示不要求进入临界区
void Pi( void )
{
while (1) {
keyi = 1;
while( keyi != 0 )
举例:临界资源
进程P1和P2共享变量count, R1和R2是处理机中的寄存器
P1: R1=count; R1=R1+1; count=R1;
P2: R2=count; R2=R2+1; count=R2;
若执行顺序变为 P1: R1=count; P2: R2=count; P1: R1=R1+1;
……; //P0的临界区代码
flag[ 0 ] =0;
//声明退出临界区
…….; // P0的非临界区代码
}
}
void P1(void)
{
while( 1 ) {
flag [ 1 ] =1; turn = 0;
//P1申请进入临界区
while( flag[0] == 1 && turn ==0) ; //等待获准进入
互斥-硬件支持2-特殊机器指令
1 Test-and-Set 处理机指令
对于同一主存块访问要求,即使两个处理机同时提 出,存储控制逻辑也只能让其中之一先访问,但在 一个处理机的两个存储周期间却可以插入另一个处 理机的存储周期。现在用一条指令来完成检测和修 改两个功能,这样中断和插入另一处理机的存储周 期均不可能,所以不会影响此公用变量数据的完整 性。
算法3 Int flag[2] = { 0, 0 } Int turn = 0;
互斥-软件的忙等待方法-3
Cobegin
void P0(void)
{
while( 1 ) {
flag [ 0 ] =1;
//P0申请进入临界区
turn = 1;
while( flag[1] == 1 && turn ==1) ; //等待获准进入
实现进程互斥和同步的信号量机制有软件方法、硬件指 令方法、信号量机制和管程等。
互斥-软件的忙等待方法-1
算法1
int flag[2]={ 0, 0 }
Cobegin
void P0(void)
{
while( 1 ) {
while ( flag[1] == 1) ;
flag[0] = 1;
……; //P0的临界区代码
算法2 int turn = 0; Cobegin
1.P0每小时进一次而P1每小时进入1000次 2.若某进程发生意外永远不能运行…..
void P0(void)
{
while( 1 ) {
while ( turn != 0 ) ;
……; //P0的临界区代码
turn = 1;
…….; // P0的非临界区代码
swap( lock, keyi );
.....;
//Pi 临界区代码
lock = 0; //退出临界区
.....;
//Pi 非临界区代码
}
}
count=R1; P2: R2=R2+1;
count=R2;
临界区Critical sections
多个进程共享临界资源时必须互斥使用,例如A 和B两个进程都需要使用打印机,它们必须互斥 使用。如果为了保证结果的正确性限制A、B二 进程推进序列,规定进程A执行好再执行进程B, 这样的限制就显得过死,因为它已不能保证进 程A、B能并发执行,所以必须把限制减少到最 少,以尽可能支持并发执行。为此把各进程分 解,把访问临界资源的那段代码(称为临界区) 与其它段代码分割开来,只对各种进程进入自 己的临界区加以限制,即各进程互斥地进入自 己的临界区。
多个相关进程在执行次序上的协调称为进程同步。 用于保证多个进程在执行次序上的协调关系的相 应机制称为进程同步机制。
准则
– 空闲让进 – 忙则等待 – 阻塞等待 – 有限等待
一个由临界区和剩余区1和剩余区2程序段组成的进程采 用进程同步机制后的描述如下:
{
remainder section 1;
剩余区1
进入区; critical section ;
临界区
退出区; remainder section 2 ; 剩余区2
}
进程同步机制在临界区前加上进入区,它负责对欲 访问的临界资源状态进行检查,以决定是允许该进程进 入临界区还是等待。同时在临界区后加上退出区,它负 责释放临界资源以便其它等待该临界资源的进程使用。
举例:临界区
While ( 1 ) { …… entry_section; critical_section; exit_section; ………
}
//申请进入 //临界区 //声明退出
进程同步机制
进程在并发执行时为了保证结果的可再现性,各 进程执行序列必须加以限制以保证互斥地使用临 界资源,相互合作完成任务。
禁止中断举例
Void Pi(void)
{
while ( 1 ) {
disable_interrupts;
……;
//临界区代码
enable_interrupts;
……; //非临界区代码
}
}
在多处理机情况下,用提高临界段代码执行的中 断优先级方法是无法保证互斥的,因为在一个处 理机上提高中断优先级并不能阻止其它处理器上 的中断,所以必须采用其它方法。