计算机操作系统感悟随笔--信号量机制

在这里插入图片描述
2.信号量的基本应用
实现进程互斥
实现进程间的前趋关系(有序)
3.整型信号量

把整型信号量定义为一个表示资源数目的整型量S,除初始化外,仅能通过两个标准的原子操作wait(S)和signal(S)来访问。

wait(S)和signal(S)操作可以描述为:

wait(S):  while S <= 0 do no-op;
      S:=S-1;
signal(S):  S:=S+1;123

wait(S)和signal(S)是两个原子操作,它们在执行时是不可中断的。当一个进程在修改某信号量时,没有其他进程能同时对该信号量进行修改。

在整型信号量机制中的wait操作中,只要是信号量S<=0,就会不断地测试。因此该机制没有遵循“让权等待”准则,而是使进程处于“忙等”的状态。
4.记录型信号量
记录型信号量机制采取了“让权等待”策略,是一种不存在“忙等”现象的进程同步机制。它所包含的数据项描述为:

typedef struct{
int value;
struct process_control_block *list;
}semaphore;

wait(S)和signal(S)操作可描述如下:
**

wait(semaphore *S){
S->values--;
if(S->value<0)block(S->list);
}
signal(semaphore *S){
S->value++;
if(S->value<=0) wakeup(S->list);
}

**

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值