热门标签 | 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. 有限等待



推荐阅读
  • 如何在Faceu激萌中设置和使用妆容切换特效?
    本文将详细介绍如何在Faceu激萌应用中设置和使用妆容切换特效,帮助用户轻松实现创意拍摄。无论是新手还是有经验的用户,都能从中受益。 ... [详细]
  • 本文介绍了拍摄高质量Vlog所需的设备,包括索尼A7 III相机、蔡司镜头、罗德麦克风、单反稳定器、苹果手机及其配件、灯光设备等。此外,还探讨了后期制作所需的软件工具,如剪辑、特效和调色软件。无论你是业余爱好者还是专业创作者,选择合适的设备至关重要。 ... [详细]
  • Python 异步编程:深入理解 asyncio 库(上)
    本文介绍了 Python 3.4 版本引入的标准库 asyncio,该库为异步 IO 提供了强大的支持。我们将探讨为什么需要 asyncio,以及它如何简化并发编程的复杂性,并详细介绍其核心概念和使用方法。 ... [详细]
  • 探讨一个老旧 PHP MySQL 系统中,时间戳字段不定期出现异常值的问题及其可能原因。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 郑州大学在211高校中的地位与排名解析
    本文将详细解读郑州大学作为一所位于河南省的211和双一流B类高校,在全国211高校中的地位与排名,帮助高三学生更好地了解这所知名学府的实力与发展前景。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 优化ASM字节码操作:简化类转换与移除冗余指令
    本文探讨如何利用ASM框架进行字节码操作,以优化现有类的转换过程,简化复杂的转换逻辑,并移除不必要的加0操作。通过这些技术手段,可以显著提升代码性能和可维护性。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 电子元件封装库:三极管、MOS管及部分LDO(含3D模型)
    本资源汇集了常用的插件和贴片三极管、MOS管以及部分LDO的封装,涵盖TO和SOT系列。所有封装均配有高质量的3D模型,共计96种,满足日常设计需求。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • 本文详细介绍了如何使用PHP检测AJAX请求,通过分析预定义服务器变量来判断请求是否来自XMLHttpRequest。此方法简单实用,适用于各种Web开发场景。 ... [详细]
  • 小红书提高MCN机构入驻门槛,需缴纳20万元保证金
    近期,小红书对MCN机构的入驻要求进行了调整,明确要求MCN机构在入驻时需缴纳20万元人民币的保证金。此举旨在进一步规范平台内容生态,确保社区的真实性和用户体验。 ... [详细]
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社区 版权所有