热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

6.3Peterson方法解决临界区问题

6.3Peterson方法解决临界区问题Peterson解决方案适用于两个进程错的执行临界区与剩余区的情况。假设两个进程是P0和P1,同时为了方便,当使用Pi时,另外一个进程使用P

6.3Peterson 方法解决临界区问题

Peterson解决方案适用于两个进程错的执行临界区与剩余区的情况。

假设两个进程是 P0 和P1 ,同时为了方便,当使用Pi时,另外一个进程使用Pj表示,即 j == 1 - i 。

Perterson 解决方案要求两个进程共享两个数据项:

int turn;
boolean flag[2];

其中,flag表示哪个进程准备进入临界区,或者说哪个进程有了进入临界区的需求,例如flag[i] == true,则说明进程Pi有需求进入临界区。turn则表示,哪一个进程可以进入临界区,如turn == 1 ,则说明现在p1可以进入临界区。

有关于Peteson解决方法的具体实现,有谦让式和争夺式两种。


一、谦让式

//课本上提供的进程i的结构
do {
flag[i] = true ;
turn = j ;
while (flag[j] && turn == j);//在进程i能够执行前会在这里无限循环
//临界区
flag[i] = false ;
//剩余区
} while (true)

为什么说这种方式是谦让式,我们可以具体的看一下两个进程在进入区的代码:

//进程i的进入区代码
flag[i] = true ;
turn = j ;
while (flag[j] && turn == j);
//进程j的进入区代码
flag[j] = true ;
turn = i ;
while (flag[i] && turn == i);

每个进程在需要进入临界区时,会先把自己对应的flag设定为 true ,表示自己需要进入临界区。然后却把 turn 设定为对方,即把进入临界区的机会“谦让”给对方,所以称为谦让式。

对于该方法的分析:

对于进程Pi ,假设它准备进入临界区,他会把自己的flag设定为true,然后把turn设定为j,将进入临界区机会让给进程j,然后便是重点:



  • 假如这时进程 j 没有进入临界区需求,即此时i、j 进程没有并发执行,那么flag[j] == false,则 进程 i 就会顺利进入临界区,相当于是谦让给对方,但对方不需要,就有拿回来了。

  • 假设这时进程 j 正在临界区中,那么这时会有 flag[j] == true && turn == j ,进程 i 会先在while中无限循环,等待进程 j 完成,把flag[j] 设定为 false。

  • 假如这时进程 j 也需要进入临界区,即此时i、j 进程并发执行。那么在这时进程 j 也会有这样的操作,把自己的flag设定为 true ,同时把turn设定为对方,把进入临界区的机会让给对方。那么,双方谦让肯定存在顺序。假设是进程 i 先谦让,那么机会会先交给进程 j 然后又谦让回来,进程 i 进入临界区,进程 j 等待。反之,假设进程 i 后谦让,那么机会最终还是要让给进程 j 的。

  • 那么我们不难推出结论,无论以上的指令是以什么次序执行的,总会有且只有一个进程获得了从对方那里让来的进入临界区的机会,而这个进程本身必然是先进行谦让的那个。

  • 在这种谦让式的peterson中,先谦让的必然是先进入临界区。


二、抢夺式

#define FALSE 0
#define TRUE 1
#define N 2 /* 进程数量 */

int turn; /* 现在轮到谁?*/
int interested[N]; /* 所有值初始化为0(FALSE)*/
void enter_region(int process) /* 进程是0或1 */
{
int other; /* 其他进程号 */
other = 1 - process; /* 另一方进程 */
interested[process] = TRUE; /* 表名所感兴趣的 */
turn = process; /* 设置标志 */
while(turn == process && interested[other] ==TRUE); /* 空语句 */
}
void leave_region(int process) /* 进程:谁离开?*/
{
interested[process] = FALSE; /* 表示离开临界区 */
}

// 关键代码
interested[process] = TRUE;
turn = process;
while(turn == process && interested[other] == TRUE);

抢占式代码和谦让式有点不一样但原理是相同的:

在抢占式,用process表示自己进程,用other表示另一个。interested[] 和flag[] 相同作用。

抢占式中,进程 i 准备进入临界区,他会把自己的interested设定为true,然后把turn设定为process,也就是自己,将进入临界区机会抢到自己手上,剩下的分析和谦让式相同。


总结

无论是谦让式还是抢夺式,他们都满足了解决临界问题的三个要求:



  1. 互斥

  2. 进步

  3. 有限等待



推荐阅读
  • 本文介绍了如何在C#应用程序中有效隐藏SQLCMD命令行窗口,确保程序运行时不会弹出黑色命令提示符窗口。 ... [详细]
  • 本文详细介绍超文本标记语言(HTML)的基本概念与语法结构。HTML是构建网页的核心语言,通过标记标签描述页面内容,帮助开发者创建结构化、语义化的Web页面。 ... [详细]
  • Windows 环境下重启 MySQL 服务的方法
    本文详细介绍了在 Windows 操作系统中如何正确地重启 MySQL 数据库服务,包括常见的权限问题及其解决方案。 ... [详细]
  • 降噪耳机与普通耳机的差异解析
    对于不太了解耳机分类的朋友来说,区分降噪耳机和普通耳机可能有些困难。本文将详细对比这两类耳机在降噪技术、效果及佩戴舒适度等方面的差异,并提供选择建议。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • 本文详细介绍了 iBatis.NET 中的 Iterate 元素,它用于遍历集合并重复生成每个项目的主体内容。通过该元素,可以实现类似于 foreach 的功能,尽管 iBatis.NET 并未直接提供 foreach 标签。 ... [详细]
  • 蒟蒻林荫小复习——莫比乌斯反演
    莫比乌斯反演积性函数:对于函数f,如果有质数p,q,使得f(p)f(q)f(pq),则函数f为积性函数设积性函数f,有和函数 显然,F由f决定,这种关系是否可以反过来?  F(1) ... [详细]
  • DedeCMS栏目列表调用中currentstyle中也支持autoindex的方法
    在《DedeCMS自增函数autoindexitemindex用法全解析》中,余斗给大家详细说明了DedeCMS中的autoindex和itemindex的日常用法,而我们在DedeCMS建站过程中,调用顶级栏目之类的会用到currentstyle属性,来实现当 ... [详细]
  • JavaScript 中创建对象的多种方式
    本文介绍了 JavaScript 中创建对象的几种常见方法,包括字面量形式、构造函数、原型对象等。每种方法都有其特点和适用场景,通过对比分析,帮助开发者选择最适合的方式。 ... [详细]
  • 随着Redis功能的不断增强和稳定性提升,其应用范围日益广泛,成为软件开发人员不可或缺的技能之一。本文将深入探讨Redis集群的部署与优化,包括主从备份机制、哨兵模式以及集群功能,帮助读者全面理解并掌握Redis集群的应用。 ... [详细]
  • 本文详细介绍了游戏中胜场数和净胜场数的计算方式,通过公式解析和实例说明,帮助玩家更好地理解这两项统计数据。文章还提供了多种计算方法及其应用场景,确保读者能够全面掌握相关知识。 ... [详细]
  • 华为Mate 60 Pro截屏指南
    了解如何在华为Mate 60 Pro上进行截屏操作。本文将详细介绍多种便捷的截屏方法,帮助用户快速掌握这一实用功能。 ... [详细]
  • 本教程将指导您如何运用Photoshop中的笔刷、路径等工具,通过高超的控制技巧,从简单图形出发,打造出令人惊艳的光束效果。适合有一定基础的用户进行尝试。 ... [详细]
  • 本文探讨了在使用Selenium进行自动化测试时,由于webdriver对象实例化位置不同而导致浏览器闪退的问题,并提供了详细的代码示例和解决方案。 ... [详细]
  • 探讨了如何解决Ajax请求响应时间过长的问题。本文分析了一个从服务器获取少量数据的Ajax请求,尽管服务器已经对JSON响应进行了缓存,但实际响应时间仍然不稳定。 ... [详细]
author-avatar
癫逼
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有