Namensräume
Varianten
Aktionen

std::reference_wrapper<T>::operator()

Von cppreference.com
 
 
Dienstprogramm-Bibliotheken
Sprachunterstützung
Typunterstützung (Basistypen, RTTI)
Bibliotheks-Feature-Test-Makros (C++20)
Programm-Dienstprogramme
Variadische Funktionen
Coroutine-Unterstützung (C++20)
Vertragsunterstützung (C++26)
Drei-Wege-Vergleich
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

Allgemeine Hilfsmittel
Relationale Operatoren (in C++20 veraltet)
 
Funktionsobjekte
Funktionsaufruf
(C++17)(C++23)
Identitätsfunktions-Objekt
(C++20)
Transparente Operator-Wrapper
(C++14)
(C++14)
(C++14)
(C++14)  
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)

Alte Binder und Adaptoren
(bis C++17*)
(bis C++17*)
(bis C++17*)
(bis C++17*)
(bis C++17*)(bis C++17*)(bis C++17*)(bis C++17*)
(bis C++20*)
(bis C++20*)
(bis C++17*)(bis C++17*)
(bis C++17*)(bis C++17*)

(bis C++17*)
(bis C++17*)(bis C++17*)(bis C++17*)(bis C++17*)
(bis C++20*)
(bis C++20*)
 
 
template< class... ArgTypes >

typename std::result_of<T&(ArgTypes&&...)>::type

    operator() ( ArgTypes&&... args ) const;
(seit C++11)
(bis C++17)
template< class... ArgTypes >

std::invoke_result_t<T&, ArgTypes...>

    operator() ( ArgTypes&&... args ) const noexcept(/* siehe unten */);
(seit C++17)
(constexpr seit C++20)

Ruft das Objekt, auf das die Referenz gespeichert ist, auf, als ob mittels INVOKE(get(), std::forward<ArgTypes>(args)...). Diese Funktion ist nur verfügbar, wenn die gespeicherte Referenz auf ein Callable-Objekt verweist.

T muss ein vollständiger Typ sein.

Inhalt

[edit] Parameter

args - Argumente, die an die aufgerufene Funktion übergeben werden sollen

[edit] Rückgabewert

Der Rückgabewert der aufgerufenen Funktion.

[edit] Ausnahmen

Kann implementierungsdefinierte Ausnahmen auslösen.

(seit C++11)
(bis C++17)
noexcept-Spezifikation:  
noexcept(std::is_nothrow_invocable_v<T&, ArgTypes...>)
(seit C++17)

[edit] Beispiel

#include <functional>
#include <iostream>
 
void f1()
{
    std::cout << "reference to function called\n";
}
 
void f2(int n)
{
    std::cout << "bind expression called with " << n << " as the argument\n";
}
 
int main()
{
    std::reference_wrapper<void()> ref1 = std::ref(f1);
    ref1();
 
    auto b = std::bind(f2, std::placeholders::_1);
    auto ref2 = std::ref(b);
    ref2(7);
 
    auto c = []{ std::cout << "lambda function called\n"; };
    auto ref3 = std::ref(c);
    ref3();
}

Ausgabe

reference to function called
bind expression called with 7 as the argument
lambda function called

[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 3764 C++17 operator() ist nicht noexcept propagiert noexcept

[edit] Siehe auch

greift auf die gespeicherte Referenz zu
(public member function) [edit]