<操作系统> 理发店问题(选做)C语言实现

问题描述:
在这里插入图片描述
代码:

#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>
#include <pthread.h>
#include <semaphore.h>

sem_t customers,barbers,mutex,wanttosit,pay,over,cash_r;
int waiting=0;

void *barber_1(void*arg)
{
   while(1){
   sem_wait(&customers);
   sem_wait(&mutex);
   sem_post(&barbers);
   sem_post(&mutex);
   printf("1号理发师开始理发\n");
   sleep(10);
   sem_post(&over);
   sem_wait(&pay);
   sem_wait(&cash_r);
   printf("1号理发师开始为客人结帐\n");
   sem_post(&cash_r); 
   waiting--;

   }
}
void *barber_2(void*arg)
{
   while(1){
   sem_wait(&customers);
   sem_wait(&mutex);
   sem_post(&barbers);
   sem_post(&mutex);
   printf("2号理发师开始理发\n");
   sleep(10);
   sem_post(&over);
   sem_wait(&pay);
   sem_wait(&cash_r);
   printf("2号理发师开始为客人结帐\n");
   sem_post(&cash_r);
   waiting--;
   }
}
void *barber_3(void*arg)
{
   while(1){
   sem_wait(&customers);
   sem_wait(&mutex);
   sem_post(&barbers);
   sem_post(&mutex);
   printf("3号理发师开始理发\n");
   sleep(10);
    sem_post(&over);
   sem_wait(&pay);
   sem_wait(&cash_r);
   printf("3号理发师开始为客人结帐\n");
   sem_post(&cash_r);
   waiting--;
   }
}

void *customer_i(int b)
{
  printf("%d号客人来了!\n",b+1);
  sem_wait(&mutex);
  if(waiting<17)
 {  
     waiting++;
     sem_post(&mutex);
     sem_post(&customers);
     switch(waiting){
     case 0 ... 3:
    {
     sem_wait(&barbers);
     printf("%d号客人正在理发\n",b+1);
     sem_wait(&over);
     printf("%d号客人去结帐\n",b+1);
     sem_post(&pay);
     break;
    }
     case 4 ... 7:
      {
        sem_wait(&wanttosit);
        printf("%d号客人去沙发等待\n",b+1); 
       sem_wait(&barbers);
       sem_post(&wanttosit);
       printf("%d号客人正在理发\n",b+1);
       sem_wait(&over);
       printf("%d号客人去结帐\n",b+1);
       sem_post(&pay);
      break;
      }
     default :
       {
       printf("%d号客人站着等待\n",b+1);
        sem_wait(&wanttosit);
       printf("%d号客人去沙发等待\n",b+1); 
       sem_wait(&barbers);
       sem_post(&wanttosit);
       printf("%d号客人正在理发\n",b+1);
       sem_wait(&over);
       printf("%d号客人去结帐\n",b+1);
       sem_post(&pay);
       break;
      }
      }
      }
      else 
       {
       printf("无位置,%d号客人离开\n",b+1);
        sem_post(&mutex);
       
        } 

}

int main()
{
	int sg1,sg2,sg3,sg4,sg5,sg6,sg7;
        pthread_t barber1,barber2,barber3,customer[100];
	sg1=sem_init(&mutex,0,1);
	sg2=sem_init(&customers,0,0);
        sg3=sem_init(&barbers,0,0);
        sg4=sem_init(&wanttosit,0,4);
        sg5=sem_init(&over,0,0);
        sg6=sem_init(&pay,0,0);
        sg7=sem_init(&cash_r,0,1);
        pthread_create(&barber1,NULL,(void *)barber_1,NULL); 
        pthread_create(&barber2,NULL,(void *)barber_2,NULL); 
        pthread_create(&barber3,NULL,(void *)barber_3,NULL); 
for(int i=0;i<=99;i++)
{      
        pthread_create(&customer[i],NULL,(void *)customer_i,i); 
        sleep(1);
}
 
         pthread_join(barber1,NULL);
         pthread_join(barber2,NULL);
         pthread_join(barber3,NULL);

for(int k=0;k<=99;k++)
{    
          pthread_join(customer[k],NULL);
}
         
        
      
          sleep(2);
	return 0;

}

运行截图
在这里插入图片描述在这里插入图片描述
在这里插入图片描述

  • 1
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值