目录
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。