进程互斥–软件实现方法

1、单标志法
算法思想:两个进程在访问完临界区后,会把使用临界区的权限交给另一个进程。每个进程进入临界区的权限只能被另一个进程赋予。
违背原则:空闲让进、让权等待
2、双标识先检查法
算法思想:设置一个布尔型数组flag[],数组中各元素用来标记进程想进入临界区的意愿,true表示想要进入。每个进程在进入临界区之前先检查当前有没有别的进程想进入临界区,如果没有,则把自身的flag设为true,之后开始访问临界区。
违背原则:忙则等待、让权等待
3、双标识后检查法
算法思想:双标识后检查法的改进版。前一个算法的问题是先检查后上锁,但是这两个操作无法一气呵成,因此导致了两个进程可能同时进入临界区。所以改进为先上锁后检查来避免上述问题。
违背原则:空闲让进、有限等待、让权等待
4、Peterson算法
算法思想:双标识后检查法中,两个进程都争着想要进入临界区,谁也不让谁,最后都无法进入临界区。Peterson算法使用了一种主动让对方先使用临界区的思想。
违背原则:让权等待

来源:samll_pebble

声明:本站部分文章及图片转载于互联网,内容版权归原作者所有,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2019年3月9日
下一篇 2019年3月9日

相关推荐