Выполнение нескольких потоков в циклическом режиме с использованием pthread_cond_wait и pthread_cond_signal в c / c ++

0

Я создал 10 потоков и хочу выполнить в циклическом режиме три раза. Первоначально все потоки ждут. Основные потоки посылают сигнал в поток 0, по сигналу потока сигнала 0 пробуждаются, а затем выполняют некоторую задачу, а затем посылают сигнал в поток 1, и это повторяется, как thread1-> thread2-> thread3....-> thread9. затем поток 9-> поток 0.

Я пытаюсь реализовать это

thread i, выполняет некоторую задачу, затем посылает сигнал в поток (i + 1), а затем поток я идет для сна. нить (i + 1) будет просыпаться после t sec (означает поток я + 1 время пробуждения - поток я sleep time = t sec), поток (i + 1) выполнит некоторую задачу, передаст сигнал в поток (i + 2) и идите спать, и это повторится в течение нескольких (3) раз.

Хотя я могу послать сигнал из потока 0-> thread 1 ->.... thread 9 (цикл выполняется только один раз), я не могу отправить поток сигнала 9 → thread 0, и поэтому я не могу повторить этот цикл 3 раза.

где я совершаю ошибки?

Любая помощь будет высоко оценена. Я использую g++ 4.6.3 под linux kernel 2.6.32.

Вот мой ожидаемый результат

    Create 5 threads
    Thread created=0
    Thread created=1
    Thread created=2
    Thread created=3
    Thread created=4
    Thread 4 blocked
    Thread 3 blocked
    Thread 2 blocked
    Thread 1 blocked
    Thread 0 blocked
    Wake up all waiting threads...
    Thread 0 unblocked
    Thread 1 unblocked
    Thread 2 unblocked
    Thread 3 unblocked
    Thread 4 unblocked

    Thread 4 blocked // repeataion of same sequence
    Thread 3 blocked
    Thread 2 blocked
    Thread 1 blocked
    Thread 0 blocked
    Thread 0 unblocked
    Thread 1 unblocked
    Thread 2 unblocked
    Thread 3 unblocked
    Thread 4 unblocked


    Wait for threads and cleanup
    Main completed

Вот мой фактический результат

Create 5 threads
Thread created=0
Thread created=1
Thread created=2
Thread created=3
Thread created=4
Thread 4 blocked
Thread 3 blocked
Thread 2 blocked
Thread 1 blocked
Thread 0 blocked
Wake up all waiting threads...
Thread 0 unblocked
Thread 1 unblocked
Thread 2 unblocked
Thread 3 unblocked
Thread 4 unblocked
Wait for threads and cleanup
Main completed

Вот мой код

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


/* For safe condition variable usage, must use a boolean predicate and   */
/* a mutex with the condition.                                           */
int                 conditionMet = 0;
pthread_cond_t      cond[5];

pthread_mutex_t     mutex = PTHREAD_MUTEX_INITIALIZER;

#define NTHREADS    5

void *threadfunc(void *parm)
{

  int i;
  long my_id = (long)parm;
  int           rc;

// Initially all threads will wait 
rc = pthread_mutex_lock(&mutex);
printf("Thread %d blocked\n",my_id);
rc = pthread_cond_wait(&cond[my_id], &mutex);
printf("Thread %d unblocked\n", my_id);
rc = pthread_mutex_unlock(&mutex);

int count=0;

while(count++<3) // This line makes no sense, no repeatation as expected. 
{

  rc = pthread_mutex_lock(&mutex);

  while (!conditionMet) {
    printf("Thread %d blocked\n",my_id);
    rc = pthread_cond_wait(&cond[my_id], &mutex);
    printf("Thread %d unblocked\n", my_id);
  }

  rc = pthread_mutex_unlock(&mutex);

  // sending signal to next thread i+1
 rc = pthread_mutex_lock(&mutex);
    rc = pthread_cond_signal(&cond[(my_id+1)%NTHREADS]);
    rc = pthread_mutex_unlock(&mutex);

   }
      return NULL;
   }

    int main(int argc, char **argv)
    {
  int                   rc=0;
  int                   i;
  pthread_t             threadid[NTHREADS];

    for(rc=0;rc<NTHREADS;rc++)
    cond[rc]= PTHREAD_COND_INITIALIZER;

  printf("Enter Testcase - %s\n", argv[0]);

  printf("Create %d threads\n", NTHREADS);
  for(i=0; i<NTHREADS; ++i) {
    rc = pthread_create(&threadid[i], NULL, threadfunc, (void *)i);
    printf("Thread created=%d\n", i);
  }

  sleep(5);  /* Sleep is not a very robust way to serialize threads */
  rc = pthread_mutex_lock(&mutex);

  /* The condition has occured. Set the flag and wake up any waiting threads */
  conditionMet = 1;
  printf("Wake up all waiting threads...\n");
  rc = pthread_cond_signal(&cond[0]);    
  rc = pthread_mutex_unlock(&mutex);      

  printf("Wait for threads and cleanup\n");
  for (i=0; i<NTHREADS; ++i) {
    rc = pthread_join(threadid[i], NULL);        
  }
  pthread_cond_destroy(&cond[0]);
  pthread_mutex_destroy(&mutex);

  printf("Main completed\n");
  return 0;
}
Теги:
multithreading

1 ответ

0

После обращения к pthread_wait я сам решил свою проблему.

Все потоки выполняются в циклической последовательности для одного раза, затем программа завершает/завершает выполнение, так как нитки нитей НЕ ОЖИДАЮТ для следующего хода, все готово.

Таким образом, чтобы выполнить одну и ту же последовательность несколько (3) раз, переменная wait должна быть изменена правильно, чтобы каждый поток дождался следующего хода до 3 выполнения.

Вот измененная программа:

void *threadfunc(void *parm)
{

  int i;
  long my_id = (long)parm;
  int           rc;

   /*
 DELETE THIS PORTION, OTHERWISE NO OUTPUT, AGAIN HANGED BEFORE SINGLE SEQUENCE.
 IT WILL NOT ENTER INSIDE LOOP while(count++<3)

    // Initially all threads will wait 
    rc = pthread_mutex_lock(&mutex);
    printf("Thread %d blocked\n",my_id);
    rc = pthread_cond_wait(&cond[my_id], &mutex);
    printf("Thread %d unblocked\n", my_id);
    rc = pthread_mutex_unlock(&mutex);
    */


int count=0;

while(count++<3)
{

  rc = pthread_mutex_lock(&mutex);
  while ( conditionMet != my_id) 
   {
    printf("Thread %d blocked\n",my_id);
    rc = pthread_cond_wait(&cond[my_id], &mutex);
    printf("Thread %d unblocked\n", my_id);
   }

    rc = pthread_mutex_unlock(&mutex);     
    rc = pthread_mutex_lock(&mutex);
    conditionMet = (my_id+1)%NTHREADS ; // This is important to wait for next time
    rc = pthread_cond_signal(&cond[(my_id+1)%NTHREADS]);
    rc = pthread_mutex_unlock(&mutex);
}
  return NULL;
}

Ещё вопросы

Сообщество Overcoder
Наверх
Меню