1. 信号量(semaphore)主要用于保护临界资源。
进程可以根据它判断是否能访问某些共享资源。
信号量除了用于访问控制外,还可用于进程同步,也就是进程间通信。
2. 信号量分类:
a. 二值信号量: 信号量的值只能取0或1,类似于互斥锁mutex,但两者又不同:
mutex 与 二值信号量的区别:
信号量强调共享资源,只要共享资源可用,其他进程同样可以修改信号量的值;
互斥锁更强调进程,占用资源的进程使用完资源后,必须由进程本身来接锁。
b. 计数信号量:信号量的值可以取任意非负值。
3. 信号量的创建:
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
int semget(key_t key, int nsems, int semflg)
返回:信号量集合的ID
key --- 键值,有ftok()获得
nsems --- 指定打开或者新创建的信号量集中将包含信号量的个数。
一个信号量集合中可以有多个信号量。
semflg --- 标识,与消息队列相同。
4. 操作信号量:
int semop(int semid, struct sembuf *sops, unsigned nsops);
功能: 对信号量进行控制
semid --- 信号量集合的ID,由semget()获得;
sops --- 是一个操作数组,表明要进行什么操作。
nsops --- sops 所致向的操作数组的元素个数
struct sembuf {
unsigned short sem_num; //semaphore index in array
short sem_op; //semaphore operation: 获取或释放信号量
short sem_flg; //operation flags
}
进程可以根据它判断是否能访问某些共享资源。
信号量除了用于访问控制外,还可用于进程同步,也就是进程间通信。
2. 信号量分类:
a. 二值信号量: 信号量的值只能取0或1,类似于互斥锁mutex,但两者又不同:
mutex 与 二值信号量的区别:
信号量强调共享资源,只要共享资源可用,其他进程同样可以修改信号量的值;
互斥锁更强调进程,占用资源的进程使用完资源后,必须由进程本身来接锁。
b. 计数信号量:信号量的值可以取任意非负值。
3. 信号量的创建:
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
int semget(key_t key, int nsems, int semflg)
返回:信号量集合的ID
key --- 键值,有ftok()获得
nsems --- 指定打开或者新创建的信号量集中将包含信号量的个数。
一个信号量集合中可以有多个信号量。
semflg --- 标识,与消息队列相同。
4. 操作信号量:
int semop(int semid, struct sembuf *sops, unsigned nsops);
功能: 对信号量进行控制
semid --- 信号量集合的ID,由semget()获得;
sops --- 是一个操作数组,表明要进行什么操作。
nsops --- sops 所致向的操作数组的元素个数
struct sembuf {
unsigned short sem_num; //semaphore index in array
short sem_op; //semaphore operation: 获取或释放信号量
short sem_flg; //operation flags
}