std::mem_fun
| Definiert in der Header-Datei <functional> |
||
| template< class Res, class T > std::mem_fun_t<Res,T> mem_fun( Res (T::*f)() ); |
(1) | (in C++11 veraltet) (removed in C++17) |
| template< class Res, class T > std::const_mem_fun_t<Res,T> mem_fun( Res (T::*f)() const ); |
(1) | (in C++11 veraltet) (removed in C++17) |
| template< class Res, class T, class Arg > std::mem_fun1_t<Res,T,Arg> mem_fun( Res (T::*f)(Arg) ); |
(2) | (in C++11 veraltet) (removed in C++17) |
| template< class Res, class T, class Arg > std::const_mem_fun1_t<Res,T,Arg> mem_fun( Res (T::*f)(Arg) const ); |
(2) | (in C++11 veraltet) (removed in C++17) |
Erzeugt ein Wrapper-Objekt für eine Memberfunktion, wobei der Zieltyp aus den Template-Argumenten abgeleitet wird. Das Wrapper-Objekt erwartet einen Zeiger auf ein Objekt vom Typ T als erstes Argument für seinen operator().
Diese Funktion und die zugehörigen Typen wurden in C++11 als veraltet markiert und in C++17 zugunsten der allgemeineren Funktionen std::mem_fn und std::bind entfernt, die beide aufrufbar Objekt-kompatible Funktionsadapter aus Memberfunktionen erstellen.
Inhalt |
[bearbeiten] Parameter
| f | - | Zeiger auf eine Memberfunktion, für die ein Wrapper erstellt werden soll |
[bearbeiten] Rückgabewert
Ein Funktions-Objekt, das f wrappt.
[edit] Exceptions
Kann implementierungsdefinierte Ausnahmen auslösen.
[bearbeiten] Anmerkungen
Der Unterschied zwischen std::mem_fun und std::mem_fun_ref besteht darin, dass ersteres einen Funktionswrapper erzeugt, der einen Zeiger auf ein Objekt erwartet, während letzteres eine Referenz erwartet.
[bearbeiten] Beispiel
Demonstriert die Verwendung von std::mem_fun und vergleicht sie mit std::mem_fn. Ein Kompilierungsmodus im Kompatibilitätsmodus C++11/14 ist möglicherweise erforderlich: g++/clang++ mit -std=c++11, cl mit /std:c++11 usw. Auf neueren Compilern, z. B. gcc-12, können Warnungen zu "deprecated declaration" ausgegeben werden, wenn nicht im C++98-Modus kompiliert wird.
#include <functional> #include <iostream> struct S { int get_data() const { return data; } void no_args() const { std::cout << "void S::no_args() const\n"; } void one_arg(int) { std::cout << "void S::one_arg()\n"; } void two_args(int, int) { std::cout << "void S::two_args(int, int)\n"; } #if __cplusplus > 201100 int data{42}; #else int data; S() : data(42) {} #endif }; int main() { S s; std::const_mem_fun_t<int, S> p = std::mem_fun(&S::get_data); std::cout << "s.get_data(): " << p(&s) << '\n'; std::const_mem_fun_t<void, S> p0 = std::mem_fun(&S::no_args); p0(&s); std::mem_fun1_t<void, S, int> p1 = std::mem_fun(&S::one_arg); p1(&s, 1); #if __cplusplus > 201100 // auto p2 = std::mem_fun(&S::two_args); // Error: mem_fun supports only member functions // without parameters or with only one parameter. // Thus, std::mem_fn is a better alternative: auto p2 = std::mem_fn(&S::two_args); p2(s, 1, 2); // auto pd = std::mem_fun(&S::data); // Error: pointers to data members are not supported. // Use std::mem_fn instead: auto pd = std::mem_fn(&S::data); std::cout << "s.data = " << pd(s) << '\n'; #endif }
Mögliche Ausgabe
s.get_data(): 42 void S::no_args() const void S::one_arg(int) void S::two_args(int, int) s.data = 42
[bearbeiten] Siehe auch
| (C++11) |
erstellt ein Funktions-Objekt aus einem Zeiger auf ein Member (Funktions-Template) |
| (in C++11 veraltet)(in C++17 entfernt) |
erstellt einen Wrapper aus einem Zeiger auf eine Member-Funktion, aufrufbar mit einer Objekt-Referenz (Funktionsvorlage) |