信号量
信号量(又名:信号灯)与其他进程间通信方式不大相同,主要用途是保护临界资源。进程可以根据它判断是否能够访问某些共享资源。除了用于访问控制外,还可以用于进程同步。
。
如图:当A要访问S时,必须先访问M。此时M必须大于0,A访问M后使M减一等于0,然后这时A才可以访问S.在A访问S时,B也想访问S。但这时M的值为0,此时B阻塞,等待A释放S使M加1.这时B访问M。。。然后重复A的过程。
分类:
Ø 二值信号量:0或者1.类似于互斥锁。信号灯强调共享资源,只要共享资源可用,其他进程就可以修改信号灯的值;
Ø 计数信号灯:可取任何非负值(来一个进程计数器加一,走一个减一。)
创建/打开
#include<sys/types.h>
#include<sys/ipc.h>
#include<sys/sem.h>
int semget (key_t key , int nsems,int semflg)
ü Key:键值 ,由ftok获得
ü Nsems:指定打开或者创建的信号灯集中将包含信号灯的数目
ü Semflg:标识,同消息队列
int semop ( int semid, struct sembuf *sops, unsigned nops)
功能:对信号量进行控制
Ø Semid:信号量集的ID
Ø Sops:是一个操作数组,表明要进行什么操作
Ø Nops:sops所指向的数组的元素个数
Struct sembuf {
Unsigned short sem_num; //semaphore index in array
Short sem_op; //semaphore operation
Short sem_flg ; //operation flags
};
Ø Sem_num :要操作的信号量在信号量集中的编号,第一个信号的编号是0
Ø Sem_op:如果值为正数,该值会加到现有的信号量值中,通常用于释放信号量;如果sem_op的值为负,而绝对值又大于信号的现值,操作将会阻塞,知道信号值大于或者等于sem_op的绝对值,通常用于获取信号量;如果sem_op的值为0,则操作将暂时阻塞,知道信号的值变为0.
Ø Sem_flg:信号操作标志,有两种:
² IPC_NOWAIT:对信号的操作不能满足时,semop()不会阻塞,并立即返回,同时设定错误信息。
² IPC_UNDO:程序结束时(不论正常与否)释放信号量,这样做的目的在于避免程序在异常情况下结束时未将锁定的资源解锁,造成该资源的永远锁定