Namensräume
Varianten
Aktionen

std::shared_future<T>::wait

Von cppreference.com
 
 
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 wait() const;
(seit C++11)

Blockiert, bis das Ergebnis verfügbar ist. valid() == true nach dem Aufruf.

Das Verhalten ist undefiniert, wenn valid() == false vor dem Aufruf dieser Funktion.

Inhalt

[bearbeiten] Parameter

(keine)

[bearbeiten] Rückgabewert

(keine)

[edit] Exceptions

Kann implementierungsdefinierte Ausnahmen auslösen.

[bearbeiten] Hinweise

Die Implementierungen werden ermutigt, den Fall zu erkennen, wenn valid() == false vor dem Aufruf und einen std::future_error mit einer Fehlerbedingung von std::future_errc::no_state auszulösen.

Der Aufruf von wait auf demselben std::shared_future von mehreren Threads ist nicht sicher; die vorgesehene Verwendung ist, dass jeder Thread, der auf denselben gemeinsamen Zustand wartet, eine Kopie eines std::shared_future hat.

[bearbeiten] Beispiel

#include <chrono>
#include <future>
#include <iostream>
#include <thread>
 
int fib(int n)
{
    if (n < 3)
        return 1;
    else
        return fib(n - 1) + fib(n - 2);
}
 
int main()
{
    std::shared_future<int> f1 = std::async(std::launch::async, []() { return fib(40); });
    std::shared_future<int> f2 = std::async(std::launch::async, []() { return fib(43); });
 
    std::cout << "waiting... " << std::flush;
    const auto start = std::chrono::system_clock::now();
 
    f1.wait();
    f2.wait();
 
    const auto diff = std::chrono::system_clock::now() - start;
    std::cout << std::chrono::duration<double>(diff).count() << " seconds\n";
 
    std::cout << "f1: " << f1.get() << '\n';
    std::cout << "f2: " << f2.get() << '\n';
}

Mögliche Ausgabe

waiting... 1.61803 seconds
f1: 102334155
f2: 433494437

[bearbeiten] Siehe auch

wartet auf das Ergebnis, gibt zurück, wenn es für die angegebene Zeitdauer nicht verfügbar ist
(public member function) [bearbeiten]
wartet auf das Ergebnis, gibt zurück, wenn es nicht verfügbar ist, bis der angegebene Zeitpunkt erreicht ist
(public member function) [bearbeiten]