Namensräume
Varianten
Aktionen

std::mem_fun

Von cppreference.com
< cpp‎ | utility‎ | functional
 
 
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*)
mem_fun
(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*)
 
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().

1) Ruft effektiv std::mem_fun_t<Res,T>(f) oder std::const_mem_fun_t<Res,T>(f) auf.
2) Ruft effektiv std::mem_fun1_t<Res,T,Arg>(f) oder std::const_mem_fun1_t<Res,T,Arg>(f) auf.

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) [bearbeiten]
(in C++11 veraltet)(in C++17 entfernt)
erstellt einen Wrapper aus einem Zeiger auf eine Member-Funktion, aufrufbar mit einer Objekt-Referenz
(Funktionsvorlage) [edit]