Partager via


condition_variable::wait_until, méthode

Bloque un thread, et définit un moment maximal auquel le thread se débloque.

template<
   class Clock,
   class Duration
>
cv_status wait_until(
   unique_lock<mutex>& Lck,
   const chrono::time_point<Clock,
   Duration>& Abs_time
);
template<
   class Clock,
   class Duration,
   class Predicate
>
bool wait_until(
   unique_lock<mutex>& Lck,
   const chrono::time_point<Clock,
   Duration>& Abs_time,
   Predicate Pred
);
cv_status wait_until(
   unique_lock<mutex>& Lck,
   const xtime *Abs_time
);
template<class Predicate>
bool wait_until(
   unique_lock<mutex>& Lck,
   const xtime *Abs_time,
   Predicate Pred
);

Paramètres

  • Lck
    Objet unique_lock<mutex>.

  • Abs_time
    Objet chrono::time_point.

  • Pred
    Toute expression qui retourne true ou false.

Valeur de retour

Méthodes qui retournent une valeur cv_status::timeout de type cv_status si l'attente se termine lorsque Abs_time s'écoule. Sinon, ces méthodes retournent cv_status::no_timeout.

Méthodes qui retournent un bool retournent la valeur de Pred.

Notes

La première méthode bloque jusqu'à ce que l'objet condition_variable soit signalé par un appel à notify_one ou notify_all ou encore jusqu'à Abs_time. Il peut également se réveiller faussement.

En effet, la deuxième méthode exécute le code suivant.

while(!Pred())
   if(wait_until(Lck, Abs_time) == cv_status::timeout)
      return Pred();
return true;

La troisième et la quatrième méthodes utilisent un pointeur vers un objet de type xtime pour remplacer l'objet chrono::time_point. L'objet xtime spécifie la durée d'attente maximale pour un signal.

Configuration requise

En-tête : condition_variable

Espace de noms : std

Voir aussi

Référence

condition_variable, classe

<condition_variable>