system v信号量函数

/*semget函数
功能 用来创建和访问一个消息队列
原型 int semget(key_t key, int nsems, int semflg)
参数 
key 信号集的名字
nsems 信号集中信号量的个数
semflg 由九个权限标志构成,他们的用法和创建文件时使用的mode模式标志一样
返回值:成功返回一个非负整数,即信号集的标识码;失败返回-1
*/
/*semctl函数
功能 用于控制信号集
原型 int semctl(int semid, int semnum, int cmd, ...);
参数 
semid 由semget返回的信号集标识码
semnum 信号集中信号量的序号
cmd 将要采取的动作
最后一个参数根据命令不同而不同
//最后一个参数或为一个结构体,不操作结构体则为0
union semun{
	int value;
	struct semid_ds *buf;
	unsigned short *array;
	struct seminfo *_buf;
}
返回值 成功返回0,失败返回-1
*/
/*semop函数
功能 用来创建和访问一个信号集
原型 int semop(int semid, struct sembuf *sops, unsigned nsops);
参数
semid 是该信号量集的标识码
sops 是一个指向一个数据结构数值的指针、
结构体为
struct sembuf{
	short sem_num;//信号量名称
	short sem_op;//计数值操作-1,1
	short sem_flg;//选项,默认为0,表示计数值小于减去的数,便会阻塞
}
nsops 信号量的个数
返回值 成功返回0,失败返回-1
*/
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <sys/mman.h>
#include <sys/ipc.h>
#include <sys/sem.h>

#include <stdlib.h>
#include <stdio.h>
#include <errno.h>
#include <string.h>

#define ERR_EXIT(m) \
		do \
		{ \
			perror(m); \
			exit(EXIT_FAILURE); \
		}while(0)
//semctl函数第四个参数
union semun{
	int value;//信号量的计数值
	struct semid_ds *buf;
	unsigned short *array;
	struct seminfo *_buf;
}
int sem_create(key_t key)//创建信号量集,具有一个信号量
{
	int semid;
	semid = semget(key, 1, IPC_CREAT | IPC_EXCL | 0666);
	if(semid == -1)
	{
		ERR_EXIT("semget");
	}
	return semid;
}
int sem_open(key_t key)//打开信号量集
{
	int semid;
	semid = semget(key, 0, 0);
	if(semid == -1)
	{
		ERR_EXIT("semget");
	}
	return semid;
}
int sem_setval(int semid, int val)//设置信号量的计数值
{
	union semun su;
	su.val = val;
	int ret;
	ret = semctl(semid, 0, SETVAL, su);//设置0号信号量的计数值
	if(ret == -1)
		ERR_EXIT("sem_setval");
	return 0;
}

int sem_getval(int semid, int val)//获取信号量的计数值
{
	int ret;
	ret = semctl(semid, 0, GETVAL, 0);
	if(ret == -1)
		ERR_EXIT("sem_getval");
	return ret;
}

int sem_d(int semid)//删除信号集
{
	int ret;
	ret = semctl(semid, 0, IPC_RMID, 0);
	if(ret == -1)
		ERR_EXIT("semctl");
	return 0;
}

int sem_p(int semid)//P操作
{
	struct sembuf sb = {0, -1, 0};//第一个0表示对第一个信号量操作,
	//-1表示对信号量计数值减1
	//第二个0表示一个选项,默认为0
	int ret;
	ret = semop(semid, &sb, 1);
	if(ret ==-1)
		ERR_EXIT("semop");
	return ret;
}
int sem_v(int semid)//V操作
{
	struct sembuf sb = {0, 1, 0};//第一个0表示对第一个信号量操作,
	//1表示对信号量计数值加1
	//第二个0表示一个选项,默认为0
	int ret;
	ret = semop(semid, &sb, 1);
	if(ret ==-1)
		ERR_EXIT("semop");
	return ret;
}

int main(int argc, char *argv[])
{
	int semid;
	semid = sem_create(1234);
	sleep(10);
	sem_d(semid);
	return 0;
}

猜你喜欢

转载自blog.csdn.net/qq_22753933/article/details/85001085
今日推荐