曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 4803|回复: 0
打印 上一主题 下一主题

peterson 算法

[复制链接]

4918

主题

5880

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34397
跳转到指定楼层
楼主
发表于 2011-3-22 11:23:55 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
peterson 算法较 dekker 算法(关于 dekker 算法分析见:http://www.groad.net/bbs/read.php?tid-3251.html)来讲显得更为简洁。

对于 P0 进程的代码为:
[C++] 纯文本查看 复制代码
    flag[0] = 1;   
    turn = 1;       
    while (flag[1] == 1 && turn == 1)
    {
        // 忙等待
    }
    // 临界区开始
    ...
    // 临界区结束
    flag[0] = 0;           


对于 P1 代码如下:
  
[C++] 纯文本查看 复制代码
  flag[1] = 1;
    turn = 0;
    while (flag[0] == 1 && turn == 0)
    {
        // 忙等待
    }
    // 临界区开始
    ...
    // 临界区结束
    flag[1] = 0; 

从 peterson 算法的代码来看,两个进程都是“谦让式” (对turn的设置)的去访问临界区。这样一来,就达到了互斥访问的效果。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2025-6-17 12:59 , Processed in 0.076545 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表