webserver 01 线程同步机制类

目录

1. 信号量class sem

2. 互斥锁class locker

3. 条件变量 class cond


1. 信号量class sem

        信号量其实是⼀个整型的计数器,主要⽤于实现进程间的互斥与同步,⽽不是⽤于缓存进程间通信的数据;

        信号量是一种特殊的变量,它只能取自然数值并且只支持两种操作:等待(P)和信号(V).假设有信号量SV,对其的P、V操作如下:

  •  P 操作,这个操作会把信号量减去 1,相减后如果信号量 < 0,则表明资源已被占⽤,进程需 阻塞等待;相减后如果信号量 >= 0,则表明还有资源可使⽤,进程可正常继续执⾏。

  • 是 V 操作,这个操作会把信号量加上 1,相加后如果信号量 <=0,则表明当前有阻塞中的进程,唤醒; 相加后信号量>0, 表明当前没有阻塞中的进程。

P 操作是⽤在进⼊共享资源之前,V 操作是⽤在离开共享资源之后,这两个操作是必须成对出现的。

信号初始化为0,代表同步信号量以保证进程 A 应在进程 B 之前执⾏

具体过程:

        如果进程B比A先执行,那么执行到P操作的时候,由于信号量初始化为0,执行P操作信号量边为-1,表示进程A还没产生数据,所以B阻塞等待;

        接着进程A生产完数据后执行了V操作,会使信号量边为0,唤醒阻塞在P的B线程

        

信号初始化为1,代表互斥信号量以保证共享内存在任何时刻只有⼀个进程在访 问,这就很好的保护了共享内存。

具体过程:

        进程 A 在访问共享内存前,先执⾏了 P 操作,由于信号量的初始值为 1,故在进程 A 执⾏ P 操作后 信号量变为 0,表示共享资源可⽤,于是进程 A 就可以访问共享内存。

         若此时,进程 B 也想访问共享内存,执⾏了 P 操作,结果信号量变为了 -1,这就意味着临界资源已 被占⽤,因此进程 B 被阻塞。

        直到进程 A 访问完共享内存,才会执⾏ V 操作,使得信号量恢复为 0,接着就会唤醒阻塞中的线程 B,使得进程 B 可以访问共享内存,最后完成共享内存的访问后,执⾏ V 操作,使信号量恢复到初始 值 1。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值