用餐哲学家和互斥初始化

时间:2013-05-17 11:46:20

标签: c++ multithreading mutex dining-philosopher

我正在努力解决餐饮哲学家的问题。所以我几乎完成了整个代码,但问题是我无法初始化监视器(我已经制作了我用c ++重写的伪代码)所以我真的不能测试程序。谁能帮助我并说出monitor / mutex_init初始化的问题是什么?

我在第18行遇到错误,结果如下:  错误:'int pthread_mutex_init'重新声明为不同类型的符号

将其更改为int pthread_mutex_init(& monitor,NULL); 不会工作!

加入 int pthread_mutex_init(pthread_mutex_t * monitor,NULL);

我收到错误:'__null'之前的预期标识符

#include <iostream>
#include <cstdio>
#include <pthread.h>
#include <cstdlib>
#include <unistd.h>

using namespace std;


char v_filozofi[5]={'O'};   //vizualni prikaz filozofa
int stapic[5]={1};          //stapici za filozofe
int broj[5];                //shema koju sam mora sloziti da imam broj filozofa

pthread_t       d_filozofi[5]; //dretve filozofa,philosopher's thread
pthread_cond_t  red_uvjeta[5];  
pthread_mutex_t monitor;        //deklariramo monitor,tj mymutex

int pthread_mutex_init(*monitor,NULL);

void ispisi_stanje(int n){
    for(int i = 0; i < 5 ;i++)  cout<< v_filozofi[i];
    cout<<"("<< n+1 << ")" <<endl;  
}

void misliti(int n){
    cout<<"Mislim " << endl;
    sleep(4);
}

void jesti(int n){
    pthread_mutex_lock(&monitor);
        v_filozofi[n]='o';
        while(stapic[n]==0 || stapic[n+1]%5==0){//gleda ima li lijevi i desni
        //stapic na raspolaganju
            pthread_cond_wait(&red_uvjeta[n],&monitor);
        }
        stapic[n] = stapic[(n+1)%5] = 0;
        v_filozofi[n] = 'X';

        ispisi_stanje(n);

    pthread_mutex_unlock(&monitor);
    sleep(2);
    pthread_mutex_lock(&monitor);
        v_filozofi[n] = 'O';

        stapic[n] = stapic[(n+1)%5] = 1; 

        pthread_cond_signal(&red_uvjeta[(n-1)%5]);
        pthread_cond_signal(&red_uvjeta[(n+1)%5]);

        ispisi_stanje(n);
    pthread_mutex_unlock(&monitor);


}

void * filozof(void *n){
    int br_fil = *((int *)n);
    while(1){
        misliti(br_fil);
        jesti(br_fil);
    }   
return 0;
}   

//MAIN  
int main(){
for(int i=0;i<5;i++){
    broj[i] = i;
    pthread_cond_init(&red_uvjeta[i],NULL);
    }
for(int i=0;i<5;i++){
    sleep(1);
    pthread_create( &d_filozofi[i],NULL,filozof,&broj[i]);
    }

for(int i=0;i<5;i++) pthread_join(d_filozofi[i],NULL);
pthread_mutex_destroy(&monitor);

return 0;
}

3 个答案:

答案 0 :(得分:1)

删除该行

int pthread_mutex_init(*monitor,NULL);

而是做

pthread_mutex_init(&monitor,NULL); 

在主要功能的开头。 (并检查它是否返回0)

因为它是你声明函数没有调用它,因为它已经声明你得到一个错误

答案 1 :(得分:0)

这个函数需要一个指针,为什么在调用之前放入“int”?我认为你混淆了原型(这是不必要的)和对函数的实际调用。

int pthread_mutex_init(*monitor,NULL);

所以:

pthread_mutex_init(&monitor,NULL);

http://pubs.opengroup.org/onlinepubs/7908799/xsh/pthread_mutex_init.html

答案 2 :(得分:0)