条件变量实现哲学家就餐

#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <unistd.h>
#include <pthread.h>
#include <string.h>
#include <semaphore.h>
pthread_mutex_t mutex[5];
pthread_cond_t cond[5];
void err_pthread(int ret, char *str)
{
        if(ret != 0)
        {
                fprintf(stderr,"%s:%s\n",str,strerror(ret));
                //pthread_exit(NULL);
                exit(1);
        }
}
void sys_err(char *str)
{
        perror(str);
        exit(1);
}
#define DELAY (sleep(rand() % 3))
void *thread_func(void *arg)
{
        long i = (long) arg;

        while(1)
        {
                pthread_mutex_lock(&mutex[i]);
                printf("thread No.%ld thinking\n",i+1);
                DELAY ;
                printf("thread No.%ld hungry\n",i+1);
                DELAY ;
                pthread_cond_wait(&cond[i], &mutex[i]);
                pthread_mutex_lock(&mutex[(i + 1) % 5]);
                printf("thread No.%ld eating\n",i+1);
                DELAY ;
                pthread_mutex_unlock(&mutex[(i + 1) % 5]);
                pthread_mutex_unlock(&mutex[i]);
                DELAY ;

        }
        
        return NULL;
}
int main(void) 
{
        long i;
        int ret;
        pthread_t tid[5];
        //init sem and threads
        for(i = 0; i<5;i++)
        {
               ret = pthread_mutex_init(&mutex[i], NULL);
               if(ret != 0)
                       sys_err("mutex init");
        }
        for(i = 0; i<5;i++)
        {
                pthread_cond_init(&cond[i], NULL);
        }
        for(i=0; i<5; i++)
        {
               ret = pthread_create(&tid[i], NULL, thread_func, (void *) i);
               if(ret != 0)
                       err_pthread(ret, "thread_create");
        //       printf("tid[%ld] = %lu\n",i,tid[i]);
        }
        int who;
        while(1)
        {
                sleep(5);
                
                who=rand() % 5;
                printf("thread No.%d start \n",who+1);
                pthread_cond_signal(&cond[who]);

        }

        return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

фора 快跑

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值