Namensräume
Varianten
Aktionen

std::atomic_ref<T>::notify_all

Von cppreference.com
< cpp‎ | atomic‎ | atomic ref
 
 
Bibliothek für nebenläufige Programmierung
Threads
(C++11)
(C++20)
this_thread Namespace
(C++11)
(C++11)
(C++11)
Kooperatives Beenden
Gegenseitiger Ausschluss
(C++11)
Allgemeines Sperrungsmanagement
(C++11)
(C++11)
(C++11)
(C++11)
(C++11)
Bedingungsvariablen
(C++11)
Semaphoren
Latches und Barriers
(C++20)
(C++20)
Futures
(C++11)
(C++11)
(C++11)
(C++11)
Sichere Wiederherstellung
(C++26)
Hazard Pointer
Atomare Typen
(C++11)
(C++20)
Initialisierung von atomaren Typen
(C++11)(veraltet in C++20)
(C++11)(veraltet in C++20)
Speicherordnung
(C++11)(deprecated in C++26)
Freie Funktionen für atomare Operationen
Freie Funktionen für atomare Flags
 
 
void notify_all() const noexcept;
(constexpr seit C++26)

Führt atomare Benachrichtigungsoperationen durch.

Entsperrt alle Threads, die in atomaren Wartevorgängen (d.h. wait()) auf *ptr blockiert sind, falls vorhanden; andernfalls tut sie nichts. Diese Überladung nimmt nur an der Überladungsauflösung teil, wenn std::is_const_v<T> false ist.

Inhalt

[bearbeiten] Hinweise

Diese Form der Änderungsdetektion ist oft effizienter als einfaches Polling oder reine Spinlocks.

[bearbeiten] Beispiel

Defect reports

Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR angewendet auf Verhalten wie veröffentlicht Korrigiertes Verhalten
LWG 3508
(P3323R1)
C++20 notify_all war bedeutungslos für const T constrained to accept only non-const T

[bearbeiten] Siehe auch

blockiert den Thread, bis er benachrichtigt wird und der atomare Wert sich ändert
(public member function) [edit]
blockiert den Thread, bis er benachrichtigt wird und der atomare Wert sich ändert
(Funktions-Template) [bearbeiten]
benachrichtigt einen Thread, der in atomic_wait blockiert ist
(Funktions-Template) [bearbeiten]