一、什么是信号量???
信号量的本质是一种数据操作锁、用来负责数据操作过程中的互斥、同步等功能。
信号量用来管理临界资源的。它本身只是一种外部资源的标识、不具有数据交换功能,而是通过控制其他的通信资源实现进程间通信。
可以这样理解,信号量就相当于是一个计数器。当有进程对它所管理的资源进行请求时,进程先要读取信号量的值,大于0,资源可以请求,等于0,资源不可以用,这时进程会进入睡眠状态直至资源可用。当一个进程不再使用资源时,信号量+1(对应的操作称为V操作),反之当有进程使用资源时,信号量-1(对应的操作为P操作)。对信号量的值操作均为原子操作。
二、
1、什么是临界资源?什么是临界区???
临界资源:一次只允许一个进程使用的资源。
临界区:访问临界资源的程序代码片段。
2、为什么要使用信号量???
为了防止多个进程在访问共享资源为引发的问题。信号量可以协调进程对共享资源的访问,也就是用来保护临界资源的。任一时刻只能有一个执行线程进入临界区。
三、linux信号量机制
3.1、头文件
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
3.2、创建/获取一个信号量集合
int semget(key_t key,int nsems,int semflg);
返回值:成功返回信号量集合的semid。失败返回-1。
key:可以用key_t ftok(const char* pathname,int proj_id)
获取。
nsems:这个参数表示你要创建的信号量集合中的信号量的个数。信号量只能以集合的形式创建。
semflg:同时使用IPC_CREAT和IPC_EXCL则会创建一个新的信号量集合。若已经存在的话则返回-1。单独使用IPC_CREAT的话会返回一个新的或者已经存在的信号量集合。
3.3、信号量结合的操作
int semop(int semid,struct sembuf *sops,unsigned nsops);
int semtimedop(int semid, struct sembuf *sops, unsigned nsops, struct timespec *timeout);
返回值:成功返回0,失败返回-1。
semid:信号量结合的id。
struct sembuf *sops:
struct sembuf
{
unsigned short sem_num;