版权声明:本文为博主原创文章,转载请标明出处:http://blog.csdn.net/leafage_m https://blog.csdn.net/Leafage_M/article/details/79726626
桌上有一个可以容纳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);
}