操作系统--进程同步(仅仅是轮廓--具体要根据实际项目再深入)

Posted sun1993

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了操作系统--进程同步(仅仅是轮廓--具体要根据实际项目再深入)相关的知识,希望对你有一定的参考价值。

1.临界资源:一次仅允许一个进程使用的资源称为临界资源。

2.临界区:对临界资源进行访问或修改的代码。

3.临界区问题:多个进程并发的对临界区进行访问或修改(至少有一个修改),导致数据不一致。

  解决临界区问题思路:相关的进程在访问自己的临界区的时候,不允许其他的进程进入自己的临界区。保证修改操作是原子操作,不被打断。

4.临界区的解决办法:

  Peterson算法:软件实现

  硬件指令实现:TestAndSet指令

  信号量S:S是一个整型变量,允许两个原子操作对S值进行修改,wait()和signal(),分别对值进行减1和加1。

  注意:信号量可以解决两种问题:互斥访问--临界区问题,将信号量值设置为1,;也可以处理其他进程同步问题比如某种进程按照某执行次序执行

5.同步问题的一般解决思路

  分析问题中涉及的关系,互斥关系,同步关系,存在几种关系就设置几个信号量,每一个信号量代表一种同步或互斥关系。

  

  

以上是关于操作系统--进程同步(仅仅是轮廓--具体要根据实际项目再深入)的主要内容,如果未能解决你的问题,请参考以下文章

操作系统——实现多个进程之间同步(Peterson改进以及面包店算法)

inux c编程:记录锁

11.2 线程概念

Linux进程管理及作业控制的启动进程

VFS对象总结

10、同步互斥机制3(进程通信)(操作系统笔记)