Namensräume
Varianten
Aktionen

std::future<T>::share

Von cppreference.com
< cpp‎ | thread‎ | future
 
 
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
 
 
std::shared_future<T> share() noexcept;

Überträgt den gemeinsam genutzten Zustand von *this, falls vorhanden, an ein std::shared_future-Objekt. Mehrere std::shared_future-Objekte können auf denselben gemeinsam genutzten Zustand verweisen, was mit std::future nicht möglich ist.

Nach dem Aufruf von share auf einem std::future ist valid() == false.

Inhalt

[edit] Parameter

(keine)

[edit] Rückgabewert

Ein std::shared_future-Objekt, das den zuvor von *this gehaltenen gemeinsam genutzten Zustand enthält, falls vorhanden, konstruiert als ob durch std::shared_future<T>(std::move(*this)).

[edit] Beispiel

[edit] Fehlerberichte

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 2556 C++11 share() erfordert, dass valid() true ist Anforderung entfernt und noexcept gemacht

[edit] Siehe auch

wartet auf einen Wert (möglicherweise von anderen Futures referenziert), der asynchron gesetzt wird
(Klassenvorlage) [bearbeiten]