一、哲学家就餐问题描述
如下图,5个哲学家用一生的时间吃饭和思考。他们共用一张圆桌,每人都有一张椅子,桌上放着5支筷子。每个哲学家感到饥饿时,会试图拿起左右的两只筷子,每位哲学家每次只能拿起一只筷子。当每位哲学家同时有两支筷子的时候,他可以吃饭。当他吃完后,他会放下筷子,并开始思考。
我们需要保证不会出现哲学家饿死的情况发生。
二、解决方法
文章将采用以下两种方法解决哲学家就餐问题
- 要求每位哲学家同时拿起两只筷子。
- 要求座位号为奇数的哲学家先拿左手的筷子,偶数的哲学家先拿右手的筷子。
三、代码
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<pthread.h>
#include<semaphore.h>
#define Phi_Number 5
pthread_mutex_t chopstick[5] ;
void *solve1(void *arg)
{
int phi = *(int *)arg;
int left,right;
switch (phi)
{
case 1:
left = 5;
right = 1;
break;
case 2:
left = 1;
right = 2;
break;
case 3:
left = 2;
right = 3;
break;
case 4:
left = 3;
right = 4;
break;
case 5:
left = 4;
right = 5;
break;
}
while(1)
{
printf("Philosopher %d is thiking !\n",phi);
sleep(1); // thinking
pthread_mutex_lock(&chopstick[left]); // Ruquest left chopstick
time_t timep11;
time (&timep11);
printf("Philosopher %d takes left chopstick %d at %s",phi,left,asctime(gmtime(&timep11)));
if (pthread_mutex_trylock(&chopstick[right]))//return 0 if success
{
pthread_mutex_unlock(&chopstick[left]); // Release left chopstick
printf("Philosopher %d release left chopstick %d\n", phi, left);
continue;
}
time_t timep1;
time (&timep1)