PThread Create не создает поток

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

FILE * f;
sem_t * s1;
sem_t * s2;
int check;
int  v1;
int  v2;
int i;

static void * client (void *arg){


    sem_getvalue(s1, &v1); printf("Client pre wait(S1) in S1 => S1 = %d\n",v1);
    sem_wait(s1);
    printf("client works...\n");
    check = sem_getvalue(s1, &v1); printf("Client.wait(S1) in S1 => S1 = %d\n",v1);
    if(check != 0) printf("sem_getvalue error");


     return 0;
    }


int main(void){

    pthread_t tidc;
    pthread_t tids;
    int rc;
    int rs;

    //Semaforo 1
    s1 = (sem_t *) malloc(sizeof(sem_t));
    check = sem_init (s1, 0, 2);
    if (check != 0) perror("s1_init failed");




    sem_getvalue(s1, &v1);

    printf("Create the semaphores: S1 = %i\n",v1 );

    sem_wait(s1);
    printf("main waits\n");
    sem_getvalue(s1, &v1); printf("Main.wait(S1) in S1 => S1 = %d\n",v1);

    rc = pthread_create (&tidc, NULL, client, 0);
    printf(" thread created ==> rc= %i\n",rc);


    return 0;

   }

Он возвращает этот вывод:

Create the semaphores: S1 = 2
main waits
Main.wait(S1) in S1 => S1 = 1
 thread created ==> rc= 0

И иногда это:

 Create the semaphores: S1 = 2
main waits
Main.wait(S1) in S1 => S1 = 1
 thread created ==> rc= 0
Client pre wait(S1) in S1 => S1 = 1
Client pre wait(S1) in S1 => S1 = 1
client works...
Client.wait(S1) in S1 => S1 = Client.wait(S1) in S1 => S1 = 0

Похоже, иногда создается два потока, а иногда ни одного. Я компилирую с gcc prog.c -lpthred и даже с gcc -pthread prog.c


person Diego Zucca    schedule 18.03.2017    source источник
comment
Возможный дубликат выхода основного потока, другой выход тоже?   -  person tofro    schedule 18.03.2017


Ответы (1)


Если многопоточная программа не делает одно и то же от одного выполнения к другому, это может быть из-за неинициализированных переменных (как в непоточных программах), но также может быть из-за состояние гонки.

В этом случае состояние гонки возникает между выполнением потока и выходом из программы.

Поскольку вы выходите из основного сразу после создания потоков, потоки завершаются (main выход из потока, другой выход тоже?). Иногда у потока есть время что-то сделать, в зависимости от состояния и загрузки ОС.

Если вы добавите некоторую фактическую обработку, большую задержку или вызов pthread_join(tdic,NULL); для ожидания завершения потока в вашей основной программе, вы получите детерминированное поведение.

person Jean-François Fabre    schedule 18.03.2017