读操作系统的设计与实现--进程互斥

1.竞争条件

 当两个或多个进程读写某些共享数据时,而最后的结果取决于进程的运行顺序时,这就称为竞争条件。包含竞争条件的程序,大多数时候运行结果良好,但是往往会发生一些无法解释的结果。事实上,只要涉及到共享资源的情况都会引发竞争条件,要避免这种错误,关键是要找出某种途径防止多个进程同时访问共享资源,这就是我们所说的互斥。在讨论互斥前,我们先来了解下临界区的概念。

2.临界区

 对共享内存进行访问的程序片段就称为临界区。如果能够防止使得两个程序不能同时处于临界区,则能够避免竞争条件。

3.互斥

 一个好的互斥解决方案,需要具备以下四个条件:

  1.任何两个进程不能同时处于临界区

    2.不应对cpu的速度和数目做任何假设

  3.临界区外的进程不得阻塞其他进程

  4.不得使进程在临界区外无休止的等待

 

转载于:https://www.cnblogs.com/hao-dotnet/archive/2013/04/10/2872326.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值