0

我正在使用信号量在 c 中实现餐饮哲学家问题。我的代码有效,尽管我对为什么根本没有发生死锁感到困惑。

代码:

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

sem_t cs[5];
pthread_t phils[5];
void pickup(int i){


    int k = (i+1)%5;
        printf("%d: HUNGRY %d %d \n",i+1,i,k);
        sem_wait(&cs[i]);
        sem_wait(&cs[k]); 
}

void putdown(int i){
    sem_post(&cs[i]);
    sem_post(&cs[(i+1) % 5]);    
    printf("%d: THINK \n",i+1);
}

void eat(int i){
    printf("%d: EAT\n",i+1);
}

void phil(void *i){
    while(1){
        usleep((rand()% 100000) + 100000);
        int n= *(int*)i;
        pickup(n);
        eat(n);
        putdown(n); 

    }
}


int main(){
    int id[5];
    while(1){
        for(int i = 0; i<5;i++){
              sem_init(&cs[i], 0, 1);
              id[i]=i;
              pthread_create (&phils[i], NULL, (void *) &phil, (void *) &id[i]);
        }

        sleep(100);
    }   

}

输出块:

2: HUNGRY 1 2 
2: EAT
2: THINK 
4: HUNGRY 3 4 
4: EAT
4: THINK 
5: HUNGRY 4 0 
5: EAT
5: THINK 
1: HUNGRY 0 1 
1: EAT
1: THINK 
3: HUNGRY 2 3 
3: EAT
3: THINK 
5: HUNGRY 4 0 
5: EAT
5: THINK 
4: HUNGRY 3 4 
4: EAT
4: THINK 
2: HUNGRY 1 2 
2: EAT
2: THINK 
1: HUNGRY 0 1 
1: EAT
1: THINK 
3: HUNGRY 2 3 
3: EAT
3: THINK 
2: HUNGRY 1 2 
2: EAT
2: THINK 
5: HUNGRY 4 0 
5: EAT
5: THINK 
4: HUNGRY 3 4 
4: EAT
4: THINK 
1: HUNGRY 0 1 
1: EAT
1: THINK 
2: HUNGRY 1 2 
2: EAT
2: THINK 
3: HUNGRY 2 3 
3: EAT
3: THINK 
4: HUNGRY 3 4 
4: EAT
4: THINK 
1: HUNGRY 0 1 
1: EAT
1: THINK 
5: HUNGRY 4 0 
5: EAT
5: THINK 
2: HUNGRY 1 2 
2: EAT
2: THINK 
3: HUNGRY 2 3 
3: EAT
3: THINK 
4: HUNGRY 3 4 
4: EAT
4: THINK 
1: HUNGRY 0 1 
1: EAT
1: THINK 
5: HUNGRY 4 0 
5: EAT
5: THINK 

我知道这是一件好事,但似乎我的线程一个接一个地执行而不是同时执行,这违背了线程的意义。

提前致谢!

4

0 回答 0