信号量-实现进程互斥,同步

一、实现进程互斥

1.分析并发进程的关键活动,划定临界区(如:对临界资源打印机的访问就应放在临界区)

2.设置互斥信号量mutex,初值为1

3.在临界区之前执行P(mutex)

4.在临界区之后执行V(mutex)

注意:

对不同的临界资源需要设置不同的互斥信号量。

P、V操作必须成对出现。缺少P(mutex)就不能保证临界资源的互斥访问。缺少V(mutex)会导致资源永不被释放,等待进程永不被唤醒。

二、实现进程同步

因为进程并发,所以进程的执行顺序是不确定的

进程同步:要让各并发进程按要求有序地推进。

P1
{
    代码1;
    代码2;
    代码3;
}
​
P2
{
    代码4
    代码5
    代码6
}

比如,P1、P2并发执行,由于存在异步性,因此二者交替推进的次序是不确定的。

若P2的“代码4”要基于P1的“代码1”和“代码2”的运行结果才能执行,那么我们就必须保证“代码4”一定是在“代码2”之后才会执行。

这就是进程同步问题,让本来异步并发的进程互相配合,有序推进。

1.实现

用信号量实现进程同步:

1.分析什么地方需要实现“同步关系”,即必须保证“一前一后”执行的两个操作(或两句代码)

2.设置同步信号量s,初始为0

3.在“前操作”之后执行v(S)

4.在“后操作”之前执行P(S)

semaphore s=0;
P1()
{
    代码1;
    代码2;
    V(s);
    代码3;
}
​
P2()
{
    P(s);
    代码4;
    代码5;
    代码6;
}
​

若先执行到v(S)操作,则S++后S=1。

之后当执行到P(S)操作时,由于S=1,表示有可用资源,会执行S--,s的值变回0,

P2进程不会执行block原语,而是继续往下执行代码4。

若先执行到P(S)操作,由于S=0,S--后S=-1

表示此时没有可用资源,因此P操作中会执行block 原语,主动请求阻塞。

之后当执行完代码2,继而执行V(S)操作,S++,使s变回0,由于此时有进程在该信号量对应的阻塞队列中,因此会在V操作中执行wakeup 原语,唤醒P2进程。这样P2就可以继续执行代码4了

三、实现进程的前趋关系

 

四、总结

 

  • 3
    点赞
  • 29
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值