Provided by: manpages-fr-extra_20151231_all bug

NOM

       pthread_cond_init,  pthread_cond_destroy, pthread_cond_signal, pthread_cond_broadcast, pthread_cond_wait,
       pthread_cond_timedwait - Opérations sur les conditions

SYNOPSIS

       #include <pthread.h>

       pthread_cond_t cond = PTHREAD_COND_INITIALIZER;

       int pthread_cond_init(pthread_cond_t *cond, pthread_condattr_t *cond_attr);

       int pthread_cond_signal(pthread_cond_t *cond);

       int pthread_cond_broadcast(pthread_cond_t *cond);

       int pthread_cond_wait(pthread_cond_t *cond, pthread_mutex_t *mutex);

       int pthread_cond_timedwait(pthread_cond_t *cond, pthread_mutex_t *mutex, const struct timespec *abstime);

       int pthread_cond_destroy(pthread_cond_t *cond);

DESCRIPTION

       Une condition (abréviation pour « variable condition ») est un mécanisme de synchronisation permettant  à
       un  thread  de suspendre son exécution jusqu'à ce qu'une certaine condition (un prédicat) sur des données
       partagées soit vérifiée. Les opérations fondamentales sur les conditions  sont :  signaler  la  condition
       (quand  le prédicat devient vrai) et attendre la condition en suspendant l'exécution du thread jusqu'à ce
       qu'un autre thread signale la condition.

       Une variable condition doit toujours être associée à un mutex, pour éviter une condition  concurrente  où
       un  thread se prépare à attendre une condition et un autre thread signale la condition juste avant que le
       premier n'attende réellement.

       pthread_cond_init() initialise la variable condition  cond,  en  utilisant  les  attributs  de  condition
       spécifiés  par  cond_attr,  ou  les  attributs  par  défaut  si  cond_attr  vaut  NULL.  L'implémentation
       LinuxThreads ne supporte aucun attribut de condition, aussi le paramètre  cond_attr  est  pour  l'instant
       ignoré.

       Les  variables  de  type pthread_cond_t peuvent également être statiquement initialisées, en utilisant la
       constante PTHREAD_COND_INITIALIZER.

       pthread_cond_signal() relance l'un des threads attendant la variable condition cond. S'il n'existe  aucun
       thread  répondant  à  ce  critère, rien ne se produit. Si plusieurs threads attendent sur cond, seul l'un
       d'entre eux sera relancé, mais il est impossible de savoir lequel.

       pthread_cond_broadcast() relance tous les threads attendant sur la variable condition cond.  Rien  ne  se
       passe s'il n'y a aucun thread attendant sur cond.

       pthread_cond_wait()  déverrouille  atomiquement  le mutex (comme pthread_unlock_mutex()) et attend que la
       variable condition cond soit signalée. L'exécution du thread est suspendue et ne consomme  pas  de  temps
       CPU  jusqu'à  ce  que  la  variable  condition soit signalée. Le mutex doit être verrouillé par le thread
       appelant  à  l'entrée  de  pthread_cond_wait().  Avant  de   rendre   la   main   au   thread   appelant,
       pthread_cond_wait() reverrouille mutex (comme pthread_lock_mutex()).

       Le  déverrouillage  du  mutex  et  la  suspension  de  l'exécution  sur  la  variable condition sont liés
       atomiquement. Donc, si tous les threads verrouillent le mutex avant de  signaler  la  condition,  il  est
       garanti  que la condition ne peut être signalée (et donc ignorée) entre le moment où un thread verrouille
       le mutex et le moment où il attend sur la variable condition.

       pthread_cond_timedwait() déverrouille le mutex et attend sur cond, en liant atomiquement ces deux étapes,
       comme  le  fait  pthread_cond_wait(),  cependant l'attente est bornée temporellement. Si cond n'a pas été
       signalée  après  la   période   spécifiée   par   abstime,   le   mutex   mutex   est   reverrouillé   et
       pthread_cond_timedwait()  rend  la  main  avec l'erreur ETIMEDOUT. Le paramètre abstime spécifie un temps
       absolu, avec la même origine que time(2) et gettimeofday(2) : un abstime de 0 correspond à 00:00:00  GMT,
       le 1er Janvier 1970.

       pthread_cond_destroy()  détruit  une  variable  condition, libérant les ressources qu'elle possède. Aucun
       thread ne doit attendre sur la condition à  l'entrée  de  pthread_cond_destroy().  Dans  l'implémentation
       LinuxThreads,   aucune   ressource   ne   peut   être   associée   à   une   variable   condition,  aussi
       pthread_cond_destroy() ne fait en fait rien d'autre que vérifier qu'aucun thread n'attend la condition.

ANNULATION

       pthread_cond_wait() et pthread_cond_timedwait() sont des points d'annulation. Si  un  thread  est  annulé
       alors qu'il est suspendu dans l'une de ces fonctions, son exécution reprend immédiatement, reverrouillant
       le paramètre mutex à pthread_cond_wait() et pthread_cond_timedwait(), et exécute finalement l'annulation.
       Aussi, les gestionnaires d'annulation sont assurés que mutex est verrouillé lorsqu'ils sont exécutés.

ASYNC-SIGNAL SAFETY

       Ces  fonctions  ne  sont  pas  fiables  par  rapport  aux signaux asynchrones et ne doivent donc pas être
       utilisées dans des gestionnaires de signaux [NdT : sous peine de perdre leur propriété  d'atomicité].  En
       particulier,  appeler  pthread_cond_signal()  ou  pthread_cond_broadcast() dans un gestionnaire de signal
       peut placer le thread appelant dans une situation de blocage définitif.

VALEUR RENVOYÉE

       Toutes ces fonctions renvoient 0 en cas de succès et un code d'erreur non nul en cas de problème.

ERREURS

       pthread_cond_init(), pthread_cond_signal(), pthread_cond_broadcast() et pthread_cond_wait() ne  renvoient
       jamais de code d'erreur.

       La fonction pthread_cond_timedwait() renvoie l'un des codes d'erreur suivants en cas de problème :

              ETIMEDOUT
                     La variable condition n'a pas reçu de signal avant le délai spécifié par abstime.

              EINTR  pthread_cond_timedwait() a été interrompu par un signal.

       La fonction pthread_cond_destroy() renvoie le code d'erreur suivant en cas de problème :

              EBUSY  Il existe des threads attendant cond.

AUTEUR

       Xavier Leroy <Xavier.Leroy@inria.fr>

VOIR AUSSI

       pthread_condattr_init(3), pthread_mutex_lock(3), pthread_mutex_unlock(3), gettimeofday(2), nanosleep(2)

EXEMPLE

       Considérons  deux  variables  globales  partagées  x  et  y,  protégées par le mutex mut, et une variable
       condition cond pour signaler que x devient plus grand que y.

              int x,y;
              pthread_mutex_t mut = PTHREAD_MUTEX_INITIALIZER;
              pthread_cond_t cond = PTHREAD_COND_INITIALIZER;

       Attendre que x devienne plus grand que y se réalise de la manière suivante :

              pthread_mutex_lock(&mut);
              while (x <= y) {
                      pthread_cond_wait(&cond, &mut);
              }
              /* operate on x and y */
              pthread_mutex_unlock(&mut);

       Les modifications de x et y qui peuvent rendre x plus grand  que  y  doivent  signaler  la  condition  si
       nécessaire :

              pthread_mutex_lock(&mut);
              /* modify x and y */
              if (x > y) pthread_cond_broadcast(&cond);
              pthread_mutex_unlock(&mut);

       S'il  peut être prouvé qu'au plus un thread en attente nécessite d'être réveillé (par exemple, s'il n'y a
       que deux threads communiquant via x et y), pthread_cond_signal() peut être utilisé en tant qu'alternative
       efficace à pthread_cond_broadcast(). En cas de doute, utilisez pthread_cond_broadcast().

       Pour attendre que x devienne plus grand que y avec un délai de 5 secondes, faîtes :

              struct timeval now;
              struct timespec timeout;
              int retcode;

              pthread_mutex_lock(&mut);
              gettimeofday(&now);
              timeout.tv_sec = now.tv_sec + 5;
              timeout.tv_nsec = now.tv_usec * 1000;
              retcode = 0;
              while (x <= y && retcode != ETIMEDOUT) {
                      retcode = pthread_cond_timedwait(&cond, &mut, &timeout);
              }
              if (retcode == ETIMEDOUT) {
                      /* timeout occurred */
              } else {
                      /* operate on x and y */
              }
              pthread_mutex_unlock(&mut);

TRADUCTION

       Cette page de manuel a été traduite par Thierry Vignaud <tvignaud AT mandriva DOT com> en 2000 et révisée
       par Alain Portal <aportal AT univ-montp2 DOT fr> en 2006. La version présente dans Debian  est  maintenue
       par  les  membres  de  la liste <debian-l10n-french AT lists DOT debian DOT org>. Veuillez signaler toute
       erreur de traduction par un rapport de bogue sur le paquet manpages-fr-extra.

                                                  LinuxThreads                                   PTHREAD_COND(3)