std::reference_wrapper<T>::operator()
Von cppreference.com
< cpp | utility | functional | reference wrapper
template< class... ArgTypes > typename std::result_of<T&(ArgTypes&&...)>::type |
(seit C++11) (bis C++17) |
|
| template< class... ArgTypes > std::invoke_result_t<T&, ArgTypes...> |
(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
Führen Sie diesen Code aus
#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) |