10.3.3 操作信号量
semop函数负责修改集合中一个或多个信号量的值,其定义如下:
int semop(int semid, struct sembuf *sops, unsigned nsops);
图10-8 信号量的创建和初始化流程图
第一个参数是通过semget获取到的信号量的标识符ID。
第二个参数是sembuf类型的指针。sembuf结构体定义在sys/sem.h头文件中。一般来说,该结构体至少包含以下三个成员变量:
struct sembuf {
unsigned short int sem_num ;
short sem_op ;
short sem_flg;
};
成员变量sem_num解决的是操作哪个信号量的问题。
因为信号量集中可能存在多个信号量,需要用这个参数来告知semop函数要操作的是哪个信号量,0表示第一个信号量,1表示第二个信号量,依此类推,最大为nsems-1,即不得超过集合中信号量的个数。
如果sem_num的值小于0,或者大于等于集合中信号量的个数,semop调用则会返回失败,并置errno为EFBIG。
一般来讲,不建议采用如下方法来初始化sembuf:
struct sembuf myopsbuf = {1,-1,0};
因为考虑到可移植性,我们并没有十足的把握可以确定sembuf结构体中成员变量的顺序和上面定义中给出的顺序是严