信号量、共享内存和消息队列常被称为IPC(Inter-Process Communicate,进程间通信)机制,或者被称为System V IPC
一、 信号量(用于管理对资源的访问)
- 信号量相关定义:
1)临界代码:同一时刻只能被一个进程访问的资源。
2)临界区域:访问临界资源的代码区域。
3)信号量:
一个特殊变量,只允许对它进行等待(wait)和发送信号(signal)两种操作。
分为两种:二进制信号量(只能取值0和1的变量)和通用变量(可以取多个正整数值的信号量)
P(信号量变量s) | 用于等待 如s的值>0,减1;s的值=0,挂起该进程 |
---|---|
V(信号量变量s) | 用于发送信号 如有进程因等待s而被挂起,让其恢复运行;如没有,则加1 |
- Linux信号量机制:信号量函数头文件:#include<sys/sem.h>
- semget函数(创建一个信号量或取得一个已有信号量的键)
int semget(key_t key,int num_sems,int sem_flags); |
---|
semget函数成功返回非零正数的值(即信号量标识符),失败返回-1; |
key:整数值 | 不相关进程可通过访问同一个信号量。 |
---|---|
semid信号量标识符: | 只有semget函数才能直接使用信号量键,所有其他信号量函数都是使用semget函数返回的信号量标识符。 |
IPC_PRIVATE:特殊信号量键值 | 创建一个只有创建者进程才能访问的信号量;在创建新的信号量时需给信号量给一个唯一的非零整数 |
num_sems | 指定需要的信号量数目,其取值几乎为1 |
sem_flag | 一组标志,操作权限; |
和IPC_CREAT做按位或操作,以创建一个新的信号量(如给的是一个已有信号量的键,不会产生错误) | |
和IPC_CREAT和IPC_EXCL:确保创建一个新的唯一的信号量(如信号量已存在,将返回错误) |
2)semop函数(用于改变信号量的值)
int semop ( int sem_id , struct sembuf *sem_ops , size_t num_sem_ops); |
---|
semop调用的一切动作是一次性完成,为避免出现使用多个信号量而可能发生竞争现象 |
3)semctl函数(用来直接控制信号量信息)
int semctl ( int sem_id , int sem_num , int command,…); |
---|
command:将要采取的动作;
常用值:(成功返回0,失败返回-1)
3.1)SETVAL:用来把信号量初始化为一个已知值(union semun/val设置)
3.2)IPC_RMID:用于删除一个已经不用的信号量标识符。
如有第四个参数,将会是一个union semun结构,至少包含以下成员:
*union semun//由程序员自己定义,但大多的Linux版本会在sem.h中给出定义
{
int val;
struct semid_ds *buf;
unsigned short array;
}
3.使用信号量
未完待续… …