二、操作系统进程管理(10)——用信号量机制实现进程互斥、同步、前驱关系

1.信号量机制实现互斥: (1)分析并发进程的关键活动,划定临界区。(如对临界区资源打印机的访问就应放在临界区) (2)设置互斥信号量mutex,初值为1。 (3)在临界区之前执行P(mutex)。 (4)在临界区之后执行V(mutex)。 (5)对不同的临界资源需要设置不同的互斥信号量。2.信号量机制实现同步: (1)进程同步:要让各并发进程按要求有序地推进。 (2)进程同步问题:由于存在异步性,导致了代码执行的先后顺序不可预知,要让...
摘要由CSDN通过智能技术生成

1.信号量机制实现互斥:


    (1)分析并发进程的关键活动,划定临界区。(如对临界区资源打印机的访问就应放在临界区)
    (2)设置互斥信号量mutex,初值为1。
    (3)在临界区之前执行P(mutex)。      //即使用资源前先申请(P操作)
    (4)在临界区之后执行V(mutex)。
    (5)对不同的临界资源需要设置不同的互斥信号量。

2.信号量机制实现同步:


    (1)进程同步:要让各并发进程按要求有序地推进。
    (2)进程同步问题:由于存在异步性,导致了代码执行的先后顺序不可预知,要让本来异步并发的进程相互配合,有序推进。
    (3)用信号量实现进程同步的过程:
        ①分析什么地方需要实现"同步关系",即必须保证"一前一后"执行的两个操作/两句代码。
        ②设置同步信号量S,初始为0。
        ③在"前操作"之后执行V(S)。        //先执行的进程使用完资源执行资源释放(V操作)
        ④在"后操作"之前执行P(S)。

如:保证代码4必须在代码2之后执行。P、V操作可以理解为系统资源的"申请"和"释放"。

//信号量机制实现同步
semaphore S=0;    //初始化同步信号量,初试值
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值