操作系统-预习笔记-Chap02-0210

本文介绍了信号量机制,包括记录型信号量、AND型信号量和信号量集的概念。记录型信号量避免了“忙等”,通过一个整型变量value和进程链表指针L实现进程同步。AND型信号量确保一次性分配所有所需资源以防止死锁。信号量集进一步扩展了这一机制,允许更灵活的资源分配策略。
摘要由CSDN通过智能技术生成
2.4.3 信号量机制

2)记录型信号量
上述的整型信号量机制中的wait操作,可知S<=0,就会不断测试。所以,该机制没有遵循“让权等待”准则,而是使进程处于“忙等”状态。记录型信号量机制则是一种不存在“忙等”现象的进程同步机制。
但在采取了“让权等待”的策略后,又会出现多个进程等待访问同一个临界资源的情况。为此,在信号量机制中,除了需要一个用于代表资源数目的整型变量value外,还应该增加一个进程链表指针L,用于链接上述的所有等待进程。记录型信号量是由于它采用了记录型的数据结构而得名的。

//记录型数据结构:
typedef struct{
   
	int value;
	struct process_control_block * list;
}semaphore;

在正确使用时,信号量>0 ,表示可用资源 的数量;信号量<0 ,代表由于申请信号量代表的资源而阻塞的进程数量
wait() 和 signal() 操作表示为:

wait(semaphore * S){
   
	S -> value --;
	if(S -> value < 0)
		block(S -> list);
}
------
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值