2014-12-05 5 views
0

Я хочу создать программу, которая создает новый поток при каждом вызове определенного метода. Вот мой рабочий код:Создание нового потока при каждом вызове метода с помощью pthread

#define NUMBER_OF_THREADS 3 

pthread_t threads[NUMBER_OF_THREADS]; 
pthread_attr_t attr; 

void *BusyWork(void *t) 
{ 
    int i; 
    long tid; 
    tid = (long)t; 

    printf("Thread %ld running...\n",tid); 
    // ... 
    printf("Thread %ld completed...\n",tid); 

    pthread_exit((void*) t); 
} 

void createNewThread(int number){ 
    printf("running createNewThread(%d)\n", number); 
    pthread_t tid; 
    int rc = pthread_create(&tid, &attr, BusyWork, (void *) (long)number); 
    if (rc) { 
     printf("ERROR; return code from pthread_create() is %d\n", rc); 
     exit(-1); 
    } 
} 

int main(int argc, char *argv[]) { 
    int i, rc; 

    //Set up thread attributes 
    pthread_attr_init(&attr); 
    pthread_attr_setdetachstate(&attr, PTHREAD_CREATE_JOINABLE); 

    //Arbitary amount of calls (My real program will call the createNewThread() funcion multiple unkown amount of times) 
    createNewThread(15); 
    createNewThread(27); 
    createNewThread(62); 
    createNewThread(500); 
    createNewThread(8864); 
    createNewThread(99999); 

    //Free attributes 
    pthread_attr_destroy(&attr); 

    //Wait for other threads still running 
    // HOW CAN I DO THIS???? 
    /*for (i=0; i< NUMBER_OF_THREADS; i++){ 
     rc = pthread_join(??? , NULL); //TODO 
     if (rc){ 
      printf("ERROR: return code from pthread_join() %d\n", rc); 
      exit(-1); 
     } 
     printf("Main: completed join with thread %d\n", i); 
    }*/ 

    printf("Main: program completed. Exiting.\n"); 


    pthread_exit(NULL); // (?) Is this part nessassary as we are on the main thread and soon to exit the program 

    return 0; 
} 

Однако, как вы можете видеть в моем кодексе, есть несколько вопросов! Например, как я могу ждать завершения всех процессов для кода, который я использую, поскольку я не отслеживаю номер потока. Также, когда поток «BusyWork» выполняется, он не очищается после него сам и остается как сиротский процесс.

Одна из моих идей заключалась в том, чтобы использовать вектор для отслеживания каждого номера потока, а затем использовать его для окончательного соединения в конце main. Однако проблема с этим состоит в том, что список массивов может быть очень большим и никогда не будет уменьшаться, даже если поток завершен.

ответ

2

Отсоединить резьбу, не присоединяться к ним. Прежде чем создать поток, увеличьте счетчик, защищенный мьютексом. Перед тем, как поток завершится, получите мьютекс и уменьшите счетчик. Теперь вы знаете, что все потоки выполняются, когда счетчик читает ноль. Вы можете использовать переменную условия, чтобы сделать счетчик подобающим, если хотите.

+0

David, у вас есть опечатка в вашем профиле: 'crytpo-currency'. – halfer

Смежные вопросы