Peterson算法】的更多相关文章

进来Bear正在学习巩固并行的基础知识,所以写下这篇基础的有关并行算法的文章. 在讲述两个算法之前,需要明确一些概念性的问题, Race Condition(竞争条件),Situations  like  this,  where  two  or  more processes  are  reading or writing some shared data and the final result depends on who runs precisely when, are called…
转自http://blog.csdn.net/l294265421/article/details/46674847 假设有两个进程需要互斥的访问某一个临界区. Peterson算法的形式如下: enterRegion(process);// process表示进程号 // 临界区 leaveRegion(process); 具体实现如下(Java实现): 有两个全局变量: // 用于表示轮到哪个进程 private int turn; // 用于表示进程进入临界区的意愿,下标对应进程号 pri…
最近一个项目中用到了peterson算法来做临界区的保护,简简单单的十几行代码,就能实现两个线程对临界区的无锁访问,确实很精炼.但是在这不是来分析peterson算法的,在实际应用中发现peterson算法并不能对临界区进行互斥访问,也就是说两个线程还是有可能同时进入临界区.但是按照代码的分析,明明可以实现互斥访问的呀,这是怎么回事呢? 首先用一个测试程序来检验一下.临界区是对一个全局变量的自加一运算,两个线程各加一百万次,最后结果应该是两百万.由于自加一运算不是原子的,如果两个线程同时进入临界…
同步 两个或两个以上随时间变化的量在变化过程中保持一定的相对关系. 互斥 对一组并发进程,一次只有一个进程能够访问一个给定的资源或执行一个给定的功能. 互斥技术可以用于解决诸如资源争用之类的冲突,还可以用于进程间的同步,使得它们可以合作.典型例子便是生产者/消费者模型. 同步互斥的实现思路主要有两种: 软件方法(这里讲的) 信号量 使用POSIX线程库(pthread_),来创建线程,管理线程,实现同步互斥. POSIX(可移植操作系统)线程是线程的POSIX标准,定义了创建和操作线程的一套AP…
转自:http://blog.csdn.net/speedme/article/details/17595821 1. 背景 首先,看个例子,进程P1,P2共用一个变量COUNT,初始值为0                                                 因为P1,P2两个进程的执行顺序是随机的,可能顺序执行也可能是并发的,由图可见,不同的执行顺序,COUNT的值会不同,这是不允许的.      像这种情况,及多个进程并发访问和操作同一数据且执行结果与访问发生的特…
1. 背景        首先,看个例子,进程P1,P2共用一个变量COUNT,初始值为0                                                 因为P1,P2两个进程的执行顺序是随机的,可能顺序执行也可能是并发的,由图可见,不同的执行顺序,COUNT的值会不同,这是不允许的.      像这种情况,及多个进程并发访问和操作同一数据且执行结果与访问发生的特定顺序有关,称为竞争条件.   2.临界区域问题      为了避免上述情况的发生于是就引入了临界区…
如何更好理解Peterson算法? 1 Peterson算法提出的背景 在我们讲述Peterson算法之间,我们先了解一下Peterson算法提出前的背景(即:在这个算法提出之前,前人们都做了哪些工作)这对于我们之后理解Peterson算法有很大的裨益. Peterson 算法是基于双线程互斥访问的LockOne与LockTwo算法而来.LockOne算法使用一个 flag 布尔数组,LockTwo 使用一个 turn的整型量,都实现了互斥,但是都存在死锁的可能.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 = - process; /*另一方进程*/ interested[process] = TRUE; /* 表明所感兴趣…
一. 进程互斥的实现方式 1. 软件方式: 保护临界区, 自己编写代码来实现对进程的控制. Dekker算法Peterson算法Lamport算法等 2. 硬件方式: 使用特殊指令保护临界区. 开关中断指令测试并加锁指令交换指令忙等待, 自旋锁 二. Lamport面包店算法 解决多线程并发访问同一个共享资源的互斥问题 这个思想来自于面包店, 医院等, 需要排队取号的场所. 顾客进入面包店前,首先抓取一个号码,然后按号码从小到大的次序依次进入面包店购买面包. 前提: 面包店按由小到大的次序发放号…
转载地址:https://my.oschina.net/hosee/blog/673628?p=%7b%7bcurrentPage+1%7d%7d 本文就将系统性的串联起那些知识点,方便复习和回顾.本文适合已经有操作系统基础的同学,一起回顾知识,本文并不详细讲解每个算法,本文意在知识串联. 通过一个例子来串联所有的知识点: 写了一个C语言程序: #include main() {   puts("Hello World!\n"); } 目的是希望在屏幕中看到Hello World的字样…