信号量创建同共享内存一样

信号量创建同共享内存一样,系统中同样需要为信号量集定制一系列专有的操作函数(semget,semctl等)

系统命令ipcs可查看当前的系统IPC的状态,在命令后使用-s参数

使用函数semget可以创建或者获得一个信号量集ID,函数原型如下:#include int semget( key_t key, int nsems, int flag);函数中参数key用来变换成一个标识符,每一个IPC对象与一个key相对应

当新建一个共享内存段时,使用参数flag的相应权限位对ipc_perm结构中的mode域赋值,对相应信号量集的shmid_ds初始化的值如表1所示

shmid_ds结构初始化值表ipc_perm结构数据初 值ipc_perm结构数据初 值Sem_otime0Sem_nsemsNsemsSem_ctime系统当前值参数nsems是一个大于等于0的值,用于指明该信号量集中可用资源数(在创建一个信号量时)

当打开一个已存在的信号量集时该参数值为0

函数执行成功,则返回信号量集的标识符(一个大于等于0的整数),失败,则返回–1

函数semop用以操作一个信号量集,函数原型如下:#include int semop( int semid, struct sembuf semoparray, size_t nops );函数中参数semid是一个通过semget函数返回的一个信号量标识符,参数nops标明了参数semoparray所指向数组中的元素个数

参数semoparray是一个struct sembuf结构类型的数组指针,结构sembuf来说明所要执行的操作,其定义如下:struct sembuf{unsigned short sem_num;short sem_op;short sem_flg;}在sembuf结构中,sem_num是相对应的信号量集中的某一个资源,所以其值是一个从0到相应的信号量集的资源总数(ipc_perm.sem_nsems)之间的整数

sem_op指明所要执行的操作,sem_flg说明函数semop的行为

sem_op的值是一个整数,如表2所示,列出了详细sem_op的值及所对应的操作

sem_op值详解Sem_op操 作正数释放相应的资源数,将sem_op的值加到信号量的值上0进程阻塞直到信号量的相应值为0,当信号量已经为0,函数立即返回

如果信号量的值不为0,则依据sem_flg的IPC_NOWAIT位决定函数动作

sem_flg指定IPC_NOWAIT,则semop函数出错返回EAGAIN

sem_flg没有指定IPC_NOWAIT,则将该信号量的semncnt值加1,然后进程挂起直到下述情况发生

信号量值为0,将信号量的semzcnt的值减1,函数semop成功返回;此信号量被删除(只有超级用户或创建用户进程拥有此权限),函数smeop出错返回EIDRM;进程捕捉到信号,并从信号处理函数返回,在此情况将此信号量的semncnt值减1,函数semop出错返回EINTR负数请求sem_op的绝对值的资源

如果相应的资源数可以满足请求,则将该信号量的值减去sem_op的绝对值,函数成功返回

当相应的资源数不能满足请求时,这个操作与sem_flg有关

sem_flg指定IPC_NOWAIT,则semop函数出错返回EAGAIN

sem_flg没有指定IPC_NOWAIT,则将该信号量的semncnt值加1,然后进程挂起直到下述情况发生:当相应的资源数可以满足请求,该信号的值减去sem_op的绝对值

成功返回;此信号量被删除(只有超级用户或创建用户进程拥有此权限),函数smeop出错返回EIDRM:进程捕捉到信号,并从信号处理函数返回,在此情况将此信号量的semncnt值减1,函数semop出错返回EINTR

以上内容由大学时代综合整理自互联网,实际情况请以官方资料为准。

相关