2010-06-04 13 views
6

Ho appena iniziato l'apprendimento pthreads API e sto seguendo il tutorial hereÈ legittimo passare un argomento come nullo *?

Tuttavia, in un esempio di programma di pthread_create, il programma di esempio crea una lunga variabile e passa il suo valore, typecasted come void*. Nella funzione di inserimento dei thread, la dereferisce come se fosse lunga.

È legittimo? Capisco se passo l'indirizzo della variabile t, ogni thread agirà sulla stessa variabile e non su una copia di esso. Possiamo farlo perché è un void* e il compilatore non ha idea di quale tipo stiamo inviando?

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

#define NUM_THREADS  5 

void *PrintHello(void *threadid) 
{ 
    long tid; 
    tid = (long)threadid; 
    printf("Hello World! It's me, thread #%ld!\n", tid); 
    pthread_exit(NULL); 
} 

int main (int argc, char *argv[]) 
{ 
    pthread_t threads[NUM_THREADS]; 
    int rc; 
    long t; 
    for(t=0; t<NUM_THREADS; t++){ 
     printf("In main: creating thread %ld\n", t); 
     rc = pthread_create(&threads[t], NULL, PrintHello, (void *)t); 
     if (rc){ 
     printf("ERROR; return code from pthread_create() is %d\n", rc); 
     exit(-1); 
     } 
    } 
    pthread_exit(NULL); 
} 
+0

Quindi la tua domanda riguarda la validità del cast o la validità del puntatore che passa come quarto argomento per pthread_create()? – qrdl

+0

@qrdl: in realtà è entrambe le cose, ma ero più interessato a passare a lungo il 4 ° argomento per pthread_create, facendo in modo che il compilatore pensasse che in realtà stai inviando un indirizzo. –

risposta

4

Questo funziona finchè sizeof(long) <= sizeof(void*) e che ogni valore di long può essere rappresentato come void*.

Meglio sarebbe passare l'indirizzo della variabile. È possibile trasmettere da T* a void* e viceversa in modo sicuro e senza presupposti.

+1

@Charles 'sizeof (void)' e 'sizeof (void *)' sono bestie diverse – qrdl

+0

@qrdl: Giusto! –

4

È legittimo come qualsiasi tipo di typecasting. Il punto è che nulla può essere fatto con il valore a cui punta l'argomento, fino a quando non è typecast, quindi tid = (long)threadid.

Verificare il vecchio Q & A When to use a void pointer?.

+0

Stai dicendo, "void *" significa "puntatore a qualcosa", ma che "qualcosa" deve essere definito prima che possa essere usato, giusto? – Abel

+0

@Abel: giusto. Il punto è quando vuoi fare qualcosa con un puntatore a cui non è possibile dare le informazioni sul tipo. –

Problemi correlati