linux线程信号量前趋关系,操作系统——信号量机制及其实现进程互斥、同步、前驱关系...

一、知识总览

12d402637e42c0a2313e037987aaa3fa.png

信号量机制的基本原理:两个或多个进程可以利用彼此间收发的简单的信号来实现“正确的”并发执行,一个进程在收到一个指定信号前,会被迫在一个确定的或者需要的地方停下来,从而保持同步或互斥。

2287d9d2bf112f868babaf2823553c94.png

二、整型信号量

bd45fa00f1f4ff8eddfa72a3f50edb88.png

三、记录型信号量

579ee83b0e868928867527db90a58aa4.png

typedef struct{intvalue;struct process *L;

}semaphore//信号量

void wait(semaphore S){//wait原语

S.value--;if(S.value<0){

block(S.L);//阻塞原语

}

}void signal(semaphore S){//signal原语

S.value++;if(S.value<=0){

wakeup(S.L);//唤醒原语

}

}

658c6940cb7e5ac73da5d7bc12662613.png

四、信号量机制总结:

863a01ed806a6c636b1c29454fbb62d0.png

34508a871b8bb5082c3f079a8207b523.png

五、信号量机制实现进程互斥

互斥信号量的初值实际上是表示某种资源的数量,而我们这里临界区同一时间段内只允许一个进程来访问,所以可以把临界区理解成一种特殊的资源,该资源只有一个,只能被分配给一个进程使用,只有这个进程释放了,才能被其他进程使用。如果一个进程需要使用临界区这种特殊的资源的时候,那么使用之前就应该对其所对应的信号量进行P操作,使用之后进行V操作。

8758760235b4c4b8caf3a2adb8802a0e.png

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

六、信号量机制实现进程同步

a3bb3506e963f8fd69264125caf25696.png

dba441aa0e73941cc39011d911aab43a.png

设置同步信号量S,初始化为0

在“前操作”之后执行V(S)

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

七、信号量机制实现前驱关系

前驱关系:只有S1执行了之后才能执行S2,只有S2执行了之后才能执行S4和S5......

19d84d08955d73ee1e66474097f6d769.png

八、总结

be8c570e256f6e0fa8cd05dafea7baa9.png

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值