操作系统--进程同步(仅仅是轮廓--具体要根据实际项目再深入)
Posted sun1993
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了操作系统--进程同步(仅仅是轮廓--具体要根据实际项目再深入)相关的知识,希望对你有一定的参考价值。
1.临界资源:一次仅允许一个进程使用的资源称为临界资源。
2.临界区:对临界资源进行访问或修改的代码。
3.临界区问题:多个进程并发的对临界区进行访问或修改(至少有一个修改),导致数据不一致。
解决临界区问题思路:相关的进程在访问自己的临界区的时候,不允许其他的进程进入自己的临界区。保证修改操作是原子操作,不被打断。
4.临界区的解决办法:
Peterson算法:软件实现
硬件指令实现:TestAndSet指令
信号量S:S是一个整型变量,允许两个原子操作对S值进行修改,wait()和signal(),分别对值进行减1和加1。
注意:信号量可以解决两种问题:互斥访问--临界区问题,将信号量值设置为1,;也可以处理其他进程同步问题比如某种进程按照某执行次序执行
5.同步问题的一般解决思路
分析问题中涉及的关系,互斥关系,同步关系,存在几种关系就设置几个信号量,每一个信号量代表一种同步或互斥关系。
以上是关于操作系统--进程同步(仅仅是轮廓--具体要根据实际项目再深入)的主要内容,如果未能解决你的问题,请参考以下文章