Operating System-进程间互斥的方案-保证同一时间只有一个进程进入临界区(2)- Peterson解法

本文接上一篇文章继续介绍如何实现同一时间只允许一个进程进入临界区的机制。本文主要介绍Peterson解法。

方案汇总

  1. 屏蔽中断
  2. 锁变量
  3. 严格轮换法
  4. TSL指令
  5. Peterson解法

一、Peterson解法

基于锁变量以及严格轮换的方法1981年,有位叫Peterson的大师提供了一个更加简单的方法来解决进程间互斥。

代码

#define N 2 //进程数为2
int turn;  //现在轮到哪个进程?
int interested[N]; //初始化置为false,即没有在临界区等待读写共享数据的

void enter_region(int process) //进入临界区
{ turn = process; int other = 1 - turn; //另一个进程
     interested[turn] = true; while(turn == process && interested[other] == true) ; //一直循环,直到other进程退出临界区
} void leave_region(int process) { interested[process] = false; }

代码非常精炼,主要通过两个变量来配合完成,一个turn和一个interested[]数组。

二、 代码分析

  • 只有process 0进入的时候:turn=0,other=1,interested[0]=true,interested[1]= false.  enter_region马上返回,process 0马上进入临界区。
  • process 0进入临界区,但还没有离开临界区,这个时候process 1进入了临界区,turn变成了1,interested[1]= true。other=0. 但是由于process 0还没有离开临界区,所以interested[0]=interested[other]一直还是true。那么这个时候process 1就会一直在enter_region中执行while,一直等待,直到process 0离开临界区把interested[0]设置为false。

考虑一个极端情况,Process 0和Process 1几乎同时调用了enter_region, 最终肯定有个线程把另外一个线程的数据给覆盖了,假定process 1覆盖了 process 0,那么这个时候turn是1。interested[0]=interested[1]=true.

  • process 0 会马上进入临界区,不执行while循环
  • process 1则会被block,因为这个时候 turn=1 && interested[0]=true,满足while循环。

这个代码真的非常尤美,不知道怎么形容,只能一遍一遍的来体会。

 

你可能感兴趣的:(Operating System-进程间互斥的方案-保证同一时间只有一个进程进入临界区(2)- Peterson解法)