Linux实验全纪录之 理发师问题

#include <pthread.h>  
#include <stdio.h>  
#include <unistd.h>  
#include <stdlib.h>  
#include <semaphore.h>  
#include <sys/time.h>  
#include <math.h>  
#define CHAIRS 5  
sem_t customers; 
sem_t barbers;  
pthread_mutex_t mutex; 
int waiting = 0; 
void *barber(void *arg);  
void *customer(void *num);  
void cut_hair(void);  
double timediff(struct timeval i,struct timeval j);  
void seed_random(void);  
double flat(void);  
double normal(void);  
double bursty(void);  
int main()  
   {  
       int i;  
       seed_random();  
       pthread_t barber_t,customer_t;  
       int error;  
       error=pthread_create(&barber_t,NULL,barber,NULL);//创建理发师线程  
       if(error!=0) 
       {  
        	printf("pthread_create is not created...\n");  
            return -1;  
       }  
       while(1) 
       {  
          usleep(30000);//等待时间如果小于理发师理发时间则会出现等待者过多,否则不会出现等待者过多的现象  
          error=pthread_create(&customer_t,NULL,customer,NULL);//创建顾客线程  
          if(error!=0) 
          {  
             printf("pthread_create is not created...\n");  
             return -1;  
          }  
       }  
    }  
double timediff(struct timeval now,struct timeval earlier)  
    {  
       if(now.tv_sec == earlier.tv_sec)  
          return (now.tv_usec - earlier.tv_usec)/1000000.0;  
       else  
          return (1000000*(now.tv_sec - earlier.tv_sec) + now.tv_usec - earlier.tv_usec)/1000000.0;  
    }  
void *barber(void *arg)  
    {  
    	while(1)  
        {  
          sem_wait(&customers);//顾客信号量-1  
          pthread_mutex_lock(&mutex);  
          waiting = waiting -1;  
          sem_post(&barbers);//  
          pthread_mutex_unlock(&mutex);  
          cut_hair();//理发  
        }  
    }  
void cut_hair(void)  
{  
    printf("  Barber:I am cutting the customer's hair...\n");  
    usleep(100000);//理发时间  
    printf("  Barber:done.\n");  
}  
void *customer(void *num)  
{  
    pthread_mutex_lock(&mutex);  
    if(waiting<CHAIRS)  
    {  
        waiting = waiting + 1;  
        sem_post(&customers);  
        pthread_mutex_unlock(&mutex);  
        sem_wait(&barbers);   
    }  
    else  
    {  
        printf("  Waiter is too much...\n");  
        pthread_mutex_unlock(&mutex);  
    }  
   
}  
void seed_random(void)  
{  
	struct timeval randtime;  
    unsigned short xsub1[3];  
    gettimeofday(&randtime,(struct timezone *)0);  
    xsub1[0] = (ushort)randtime.tv_usec;  
    xsub1[1] = (ushort)(randtime.tv_usec >> 16);  
    xsub1[2] = (ushort)(getpid());  
    seed48(xsub1);  
}  
double flat()  
{  
    return drand48()/5;  
} 
double normal()
{
	return sin(M_PI*drand48())/M_PI/2.006999;
}

double bursty()
{
	return (sin(M_PI+drand48()*M_PI)+1.)/3.591;
}


编译时 加上-lpthread -lm
  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值