信号量概念及初级编程实战

标题信号量概念及初级编程实战

1相关概念:
以一个停车场的运作为例。简单起见,假设停车场只有三个车位,一开始三个车位都是空的。这时如果同时来了五辆车,看门人允许其中三辆直接进入,然后放下车拦,剩下的车则必须在入口等待,此后来的车也都不得不在入口处等待。这时,有一辆车离开停车场,看门人得知后,打开车拦,放入外面的一辆进去,如果又离开两辆,则又可以放入两辆,如此往复。
在这个停车场系统中,车位是公共资源,每辆车好比一个线程,看门人起的就是信号量的作用。信号量等同于钥匙,只有获取了钥匙才能进入进程,同时在退出进程后,又必须将钥匙放回到原处,即p操作和v操作。
2相关api的介绍
a: semget获取创建信号量api:
int semget(key_t key, int nsems, int semflg);
b: semctl初始化信号量:
//int semctl(int semid, int semnum, int cmd, …);
c:拿走放回钥匙api semop:
//int semop(int semid, struct sembuf *sops, unsigned nsops);
3初级父子进程间信号量操作编程实战:
#include <stdio.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>
//int semget(key_t key, int nsems, int semflg);
//int semctl(int semid, int semnum, int cmd, …);
//int semop(int semid, struct sembuf sops, unsigned nsops);
union semun
{
int val; /
Value for SETVAL */
struct semid_ds buf; / Buffer for IPC_STAT, IPC_SET */
unsigned short array; / Array for GETALL, SETALL */
struct seminfo __buf; / Buffer for IPC_INFO
(Linux-specific) */
};
void pGetKey(int id)//int semop(int semid, struct sembuf *sops, unsigned nsops);
{
struct sembuf set;
set.sem_num=0;
set.sem_op =-1;
set.sem_flg=SEM_UNDO;
semop(id,&set,1);
printf(“get key\n”);
}
void vPutBackKey(int id)//
{
struct sembuf set;
set.sem_num=0;
set.sem_op =1;
set.sem_flg=SEM_UNDO;
semop(id,&set,1);
printf(“put back the key\n”);
}
int main()
{
key_t key;
int semid;
key=ftok(".",1);
//信号量集合中有一个信号量
semid=semget(key,1,IPC_CREAT|0666);//获取,创建信号量
union semun initsem;
//操作第0个信号量
initsem.val=0;
semctl(semid,0,SETALL,initsem);//初始化信号量
//设置信号量的值,设置为initsem
int pid=fork();
if(pid>0){
pGetKey(semid);
printf(“this is father\n”);
vPutBackKey(semid);
}else if(pid==0){
vPutBackKey(semid);
printf(“this is child\n”);
}else{
printf(“creat pid failuer\n”);
}
printf(“wencai hen shuai”);
return 0;
}
由此代码则可实现信号量控制父子进程先后运行的顺序,保证先运行的是子进程。

©️2020 CSDN 皮肤主题: 数字20 设计师:CSDN官方博客 返回首页