使用信号量机制解决家庭吃水果问题。

桌上有一个可以容纳3个水果的盘子,每次只能放或取一个水果,爸爸负责削苹果,妈妈负责剥桔子,儿子只吃苹果,女儿只吃橘子。

使用信号量机制来解决。

设置一个empty变量表示盘中还有几个空位置,然后设置apple和orange记录盘中苹果和橘子的数量。

运行结果:

这里写图片描述

源代码:

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <pthread.h>
#include <errno.h>
#include <sys/ipc.h>
#include <semaphore.h>

int empty=3;//声明一个全局标量,代表有水果的空位置
int apple = 0;// 苹果的数量
int orange = 0;// 橘子的数量
sem_t sem;//信号量

void father(void *arg) {

    int i;
    while(empty) {// 如果盘中位置还有剩余,则放入一个苹果
        sem_wait(&sem);//信号量减1,P操作。
        apple++;
    empty--;
        printf("爸爸放盘中放入一个苹果,此时苹果有%d个,橘子有%d个。\n",apple,orange);
        sem_post(&sem);//信号量加1,V操作。
        sleep(2);
    }

}

void mother(void *arg) {

    while(empty) {
        sem_wait(&sem);//信号量减1,P操作。
    orange++;
    empty--;
        printf("妈妈向盘中放入一个橘子,此时苹果有%d个,橘子有%d个。\n",apple,orange);
        sem_post(&sem);//信号量加1,V操作。
        sleep(2);
    }

}

void son(void *arg) {

    while(apple) {// 如果盘中有苹果
        sem_wait(&sem);//信号量减1,P操作。
        apple--;
        empty++;
        printf("儿子吃了一个苹果,此时苹果有%d个,橘子有%d个。\n",apple,orange);
        sem_post(&sem);//信号量加1,V操作。
        sleep(3);
    }

}

void daughter(void *arg) {

    while(orange) {// 如果盘中有橘子
        sem_wait(&sem);//信号量减1,P操作。
        orange--;
        empty++;
        printf("女儿吃了一个橘子,此时苹果有%d个,橘子有%d个。\n",apple,orange);
        sem_post(&sem);//信号量加1,V操作。
        sleep(3);
    }
}



void main(int argc,char *argv[]) {
    pthread_t id1,id2,id3,id4;

    int ret;
    ret = sem_init(&sem,0,1);//初始化信号量为1

    if(ret != 0) {
        perror("sem_init");
    }

    ret = pthread_create(&id1,NULL,(void*)father,NULL);//创建线程1
    if(ret != 0) {
        perror("pthread1 cread1");
    }

    ret = pthread_create(&id2,NULL,(void*)mother,NULL);//创建线程2
    if(ret != 0) {
        perror("pthread2 cread2");
    }

    ret = pthread_create(&id3,NULL,(void*)son,NULL);//创建线程3
    if(ret != 0) {
        perror("pthread3 cread3");
    }

    ret = pthread_create(&id4,NULL,(void*)daughter,NULL);//创建线程3
    if(ret != 0) {
        perror("pthread4 cread4");
    }

    pthread_join(id1,NULL);//等待线程1完成
    pthread_join(id2,NULL);//等待线程2完成
    pthread_join(id3,NULL);//等待线程3完成
    pthread_join(id4,NULL);//等待线程4完成

    exit(0);

}
  • 5
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值