信号量:它描述了当前某种资源的数量。它的意图在于进程间同步,就相当于一个计数器,它本身不具有数据交换的功能,而是通过控制其他通信资源来实现进程间通信。

当一个进程要访问临界资源时,先要进行P操作申请资源,当大于0时,资源可以请求,申请过后,若为0,则将进程挂起;当进程不再访问该信号量控制的资源时,进行V操作,若有进程挂起,则唤醒该等待的进程继续恢复访问,如果无挂起进程,就给它加1。

进程间同步:对临界资源的访问带有顺序性的,一个执行完毕,另一个才可以执行。

注意:对信号量的操作均为原子操作,因为信号量的主要作用就是维护资源的互斥或多进程的同步访问,而在信号量的初始化和创建中均不能保证其原子操作。

创建信号量:semget(key_t key,int nsems,int semflg);

P,V操作:

semop(int semid,struct sembuf* buf,unsigned nsops);//对当前信号量集上的第几个信号量进行P/V操作

释放信号量:semctl(int semid ,int semnue,int cmd)//对当前信号量集上的第几个信号量进行cmd指令操作。

union semun { 

 int val; // 使用的值 

 struct semid_ds *buf; // IPC_STAT、IPC_SET 使用缓存区 

 unsigned short *array; // GETALL,、SETALL 使用的数组 

 struct seminfo *__buf; // IPC_INFO(Linux特有) 使用缓存区 

}; 

comm.h

wKiom1cQ9AmhWFNmAABzmsTGuYE617.png

comm.c

wKioL1cQ9PaBEQxGAABcHci9iZ4184.png

wKioL1cQ9PfBNgMaAABQOLEecDw872.png

wKiom1cQ9D6AdnzhAAAiWstxkco483.png

test.c
wKiom1cQ9F2jU7mGAABV_uTjZzQ401.png

运行结果:

wKiom1cQ9H6TSffIAAAtJnMKjg4580.png