使用pthread进行可变更改

时间:2013-04-24 17:53:07

标签: c pthreads

我正在使用pthread在C中做一个小游戏。 我有一个矩阵(int的2d表),它有一些由数字表示的字符(3,4,5,其他数字不是线程)。 那些角色必须在我的矩阵中移动。 serveurAff用于显示表格。

tabDtabCrimtabJournaliste是全球性的。它们都是指针。

这是我main的代码:

int statut, i,arg[2];
while (!serveurAff.fin)
    pthread_cond_wait(&serveurAff.termine, &serveurAff.mutex);
serveurAff.reqATraiter = 1;
serveurAff.fin = 0;
pthread_cond_signal(&serveurAff.requete);
pthread_mutex_unlock(&serveurAff.mutex);
//detective thread
for(i = 0; i < 3; i++){
    arg[0] = tabD[i]->posY;
    arg[1] = tabD[i]->posX;
    printf("test1 \n ");
    statut = pthread_create(&tabD[i]->threaddete, NULL, routinePersonne, (void *) &arg);
}
//criminel thread
for(i = 0; i < 5; i++){
    arg[0] = tabCrim[i]->posY;
    arg[1] = tabCrim[i]->posX;
    printf("test2 \n ");
    statut = pthread_create(&tabCrim[i]->threadcrim, NULL, routinePersonne, (void *) &arg);
}
//thread journaliste
for(i = 0; i < 3; i++){
    arg[0] = tabJournaliste[i]->posY;
    arg[1] = tabJournaliste[i]->posX;
    printf("test3 \n ");
    statut = pthread_create(&tabJournaliste[i]->threadjour, NULL, routinePersonne, (void *) &arg);
}
pthread_join(threadAff, NULL);

当我在开始我的pthread之前写printf时,对于“某些迭代”位置是可以的

   test1 
 test1 
 test1 
 test2 
 test2 
 test2 
 test2 
 test2 
 test3 
 test3 
 test3 
 coord1 => 9, coord0, 1 
xancien => 9 yancien => 1 
coord1 => 20, coord0, 7 
xancien => 20 yancien => 7 
azazaz









Etape 0
01   5 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
02   0 4 4 4 0 0 0 0 0 0 0 2 2 0 0 0 0 0 0 0 0 0 5 0 0 0 0 0 0 0 
03   0 0 0 0 0 0 0 0 0 3 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
04   0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 3 0 0 0 0 0 0 0 0 0 0 0 0 0 
05   0 0 3 0 0 2 2 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 5 0 0 0 0 0 0 
coord1 => 2, coord0, 4 
xancien => 2 yancien => 4 
coord1 => 0, coord0, 0 
coord1 => 20, coord0, 7 
xancien => 20 yancien => 7 
coord1 => 23, coord0, 4 
xancien => 23 yancien => 4 
xancien => 0 yancien => 0 
coord1 => 0, coord0, 0 
xancien => 0 yancien => 0 
coord1 => 20, coord0, 7 
xancien => 20 yancien => 7 
06   0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 5 0 0 0 0 0 0 
07   0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
08   0 0 0 0 0 0 0 0 0 0 0 0 1 1 0 0 0 0 0 0 0 5 0 3 0 0 0 3 0 0 
09   0 0 0 0 0 0 0 0 0 0 0 5 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 
coord1 => 23, coord0, 4 
xancien => 23 yancien => 4 
coord1 => 0, coord0, 0 
xancien => 0 yancien => 0 
coord1 => 0, coord0, 0 
xancien => 0 yancien => 0 
coord1 => 0, coord0, 0 
xancien => 0 yancien => 0 

正如您在一些迭代后所看到的,所有值都是0 ...... 如果我在开始我的线程之前不写printf("test1"),则值始终等于0.

这是routinePersonne的一部分:

void *routinePersonne(void *arg) {
while (1){
int* coord = (int*)arg;     
        int xancien = coord[1]; 
        int yancien = coord[0];
        printf("coord1 => %d, coord0, %d \n",xancien,yancien);
        printf("xancien => %d yancien => %d \n",xancien,yancien);

        int i =0;
        crimines* c;
        detective* d;
        journaliste* j;
        //on récupére le type de la personne
        int element = g->carte[yancien][xancien];
        switch(element){
            case CRIMINEL:
                c = malloc(sizeof(criminels));
                while(tabCrim[i]->posX != xancien && tabCrim[i]->posY != yancien){
                    i++;
                }
                c = tabCrim[i];
            break;
            case DETECTIVE:
                d = malloc(sizeof(detective));
                while(tabD[i]->posX != xancien && tabD[i]->posY != yancien){
                    i++;
                }
                d = tabD[i];
            break;
            case JOURNALISTE:
                j = malloc(sizeof(journaliste));
                while(tabJournaliste[i]->posX != xancien && tabJournaliste[i]->posY != yancien){
                    i++;
                }
                j = tabJournaliste[i];
        }
...
}

所以我认为这是同步问题,但我不知道在哪里......

ps:对不起我的英语:)

1 个答案:

答案 0 :(得分:0)

对所有线程使用相同的arg数组。所以你的线程将共享一组坐标。虽然我仍然无法准确指出这些坐标变为零的代码行,但很可能是某些posYposX的重新初始化占了这一点。没有代码就很难说清楚。

另一方面,你的malloc调用看起来毫无意义,因为你不对该内存做任何事情,甚至最终覆盖指针,从而造成内存泄漏。也许您错过了C没有数组赋值运算符的事实。如果a = b类型为aint*类型为bint*,则可以写int[],但这样不会复制所有元素,而只是将数组b的地址存储在变量a中。使用memcpy创建副本。