Linux进程间通信——信号量2,利用信号量实现三个进程a,b,c分别输出“A“,“B“,“C“,要求输出的结果必须是”ABCABCABC...“

多个信号量

三个进程a,b,c分别输出"A","B","C",要求输出的结果必须是"ABCABCABC...";

思路:

代码演示:

cpp 复制代码
//sem.h
typedef union senum
{
    int val;
}SemUn;

int GetSem(int key,int initval[],int n); 
int DelSem(int semid);
int SemP(int semid,int index);
int SemV(int semid,int index);
cpp 复制代码
//sem.c
#include "sem.h"
#include <sys/sem.h>
#include <stdio.h>

int GetSem(int key,int initval[],int n)
{
    int semid=semget((key_t)key,n,0600|IPC_CREAT|IPC_EXCL);
    if(semid==-1)
    {   
        semid=semget((key_t)key,n,0600);
        if(semid==-1)
        {
            printf("semget error!\n");
            return -1; 
        }
    }   
    else
    {   
        int i=0;
        for(;i<n;i++)
        {
            SemUn data;
            data.val=initval[i];
            int res=semctl(semid,i,SETVAL,data);
            if(res==-1)
            {
                printf("semcil error");
                DelSem(semid);
                return -1; 
            }
        }
    }
        return semid;
}

int SemP(int semid,int index)
{
    struct sembuf buf;
    buf.sem_num=index;//第几个信号量S1,S2,S3
    buf.sem_op=-1;
    buf.sem_flg=SEM_UNDO;

    int res=semop(semid,&buf,1);
    if(res==-1)
    {
        printf("semop p error!\n");
        return -1;
    }
    return 0;
}

int SemV(int semid,int index)
{
    struct sembuf buf;
    buf.sem_num=index;//第几个信号量S1,S2,S3
    buf.sem_op=1;
    buf.sem_flg=SEM_UNDO;
    int res=semop(semid,&buf,1);
    if(res==-1)
    {
        printf("semop v error!\n");
        return -1;
    }
    return 0;
}

int DelSem(int semid)
{
    if(semctl(semid,0,IPC_RMID)==-1)
    {
        perror("semctl del error!\n");
        return -1;
    }
    return 0;
}
          
cpp 复制代码
//a.c
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <time.h>
#include <unistd.h>
#include "sem.h"

int main()
{
    srand(time(NULL));
    int initval[]={1,0,0};
    int semid=GetSem(1234,initval,3);
    assert(semid!=-1);

    int count=0;
    while(count<5)
    {   
        SemP(semid,0);
        printf("A");
        fflush(stdout);
        int n=rand()%3;
        sleep(n);
        SemV(semid,1);
        count++;
    }   
    exit(0);
}
cpp 复制代码
//b.c
include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <time.h>
#include <unistd.h>
#include "sem.h"

int main()
{
    srand(time(NULL));
    int initval[]={1,0,0};
    int semid=GetSem(1234,initval,3);
    assert(semid!=-1);

    int count=0;
    while(count<5)
    {   
        SemP(semid,1);
        printf("B");
        fflush(stdout);
        int n=rand()%3;
        sleep(n);
        SemV(semid,2);
        count++;
    }   
    exit(0);
}
cpp 复制代码
//c.c
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <time.h>
#include <unistd.h>
#include "sem.h"

int main()
{
    srand(time(NULL));
    int initval[]={1,0,0};
    int semid=GetSem(1234,initval,3);
    assert(semid!=-1);

    int count=0;
    while(count<5)
    {   
        SemP(semid,2);
        printf("C");
        fflush(stdout);
        int n=rand()%3;
        sleep(n);
        SemV(semid,0);
        count++;
    }   
    DelSem(semid);//最后一个退出的销毁
    exit(0);
}

运行结果:

相关推荐
x66ccff2 分钟前
【linux】4张卡,坏了1张,怎么办?
linux·运维·服务器
jjb_23622 分钟前
LinuxC高级作业2
linux·bash
OH五星上将31 分钟前
OpenHarmony(鸿蒙南向开发)——小型系统内核(LiteOS-A)【扩展组件】上
linux·嵌入式硬件·harmonyos·openharmony·鸿蒙开发·liteos-a·鸿蒙内核
拾光师1 小时前
linux之网络命令
linux·服务器·网络
我命由我123452 小时前
GPIO 理解(基本功能、模拟案例)
linux·运维·服务器·c语言·c++·嵌入式硬件·c#
皓月盈江2 小时前
Linux ubuntu debian系统安装UFW防火墙图形化工具GUFW
linux·ubuntu·debian·防火墙·ufw·gufw
kka杰2 小时前
Linux 进程3
linux·运维·服务器
没有名字的小羊2 小时前
Linux基础命令——账户简单管理
linux·运维·服务器·网络·数据库
kka杰2 小时前
Linux 进程2
linux·运维·服务器
大白菜和MySQL2 小时前
tomcat服务搭建部署ujcms网站
java·linux·运维·服务器·tomcat