Namespaces
Variants

std:: mem_fun

From cppreference.net
Utilities library
Function objects
Function invocation
(C++17) (C++23)
Identity function object
(C++20)
Old binders and adaptors
( until C++17* )
( until C++17* )
( until C++17* )
mem_fun
( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
( until C++20* )
( until C++20* )
( until C++17* ) ( until C++17* )
( until C++17* ) ( until C++17* )

( until C++17* )
( until C++17* ) ( until C++17* ) ( until C++17* ) ( until C++17* )
( until C++20* )
( until C++20* )
Défini dans l'en-tête <functional>
template < class Res, class T >
std:: mem_fun_t < Res,T > mem_fun ( Res ( T :: * f ) ( ) ) ;
(1) (déprécié en C++11)
(supprimé en C++17)
template < class Res, class T >
std:: const_mem_fun_t < Res,T > mem_fun ( Res ( T :: * f ) ( ) const ) ;
(1) (déprécié en C++11)
(supprimé en C++17)
template < class Res, class T, class Arg >
std:: mem_fun1_t < Res,T,Arg > mem_fun ( Res ( T :: * f ) ( Arg ) ) ;
(2) (déprécié en C++11)
(supprimé en 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) (déprécié en C++11)
(supprimé en C++17)

Crée un objet wrapper de fonction membre, en déduisant le type cible à partir des arguments du template. L'objet wrapper attend un pointeur vers un objet de type T comme premier paramètre de son operator ( ) .

1) Appelle effectivement std:: mem_fun_t < Res,T > ( f ) ou std:: const_mem_fun_t < Res,T > ( f ) .
2) Appelle effectivement std:: mem_fun1_t < Res,T,Arg > ( f ) ou std:: const_mem_fun1_t < Res,T,Arg > ( f ) .

Cette fonction et les types associés ont été dépréciés en C++11 et supprimés en C++17 au profit des solutions plus générales std::mem_fn et std::bind , qui créent tous deux des objets fonction compatibles avec les adaptateurs à partir de fonctions membres.

Table des matières

Paramètres

f - pointeur vers une fonction membre pour laquelle créer un wrapper

Valeur de retour

Un objet fonction encapsulant f .

Exceptions

Peut lever des exceptions définies par l'implémentation.

Notes

La différence entre std :: mem_fun et std:: mem_fun_ref est que le premier produit un wrapper de fonction qui attend un pointeur vers un objet, tandis que le second — une référence.

Exemple

Illustre l'utilisation de std::mem_fun et la compare avec std::mem_fn . Un mode de compilation compatible C++11/14 peut être nécessaire : g++/clang++ avec -std=c++11, cl avec /std:c++11, etc. Sur les compilateurs récents, par exemple gcc-12, des avertissements "déclaration obsolète" peuvent être émis si la compilation n'est pas effectuée en mode C++98.

#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); // Erreur : mem_fun ne prend en charge que les fonctions membres
                                          // sans paramètres ou avec un seul paramètre.
                                          // Ainsi, std::mem_fn est une alternative préférable :
    auto p2 = std::mem_fn(&S::two_args);
    p2(s, 1, 2);
//  auto pd = std::mem_fun(&S::data); // Erreur : les pointeurs vers les membres de données ne sont pas pris en charge.
                                      // Utilisez std::mem_fn à la place :
    auto pd = std::mem_fn(&S::data);
    std::cout << "s.data = " << pd(s) << '\n';
#endif
}

Sortie possible :

s.get_data(): 42
void S::no_args() const
void S::one_arg(int)
void S::two_args(int, int)
s.data = 42

Voir aussi

(C++11)
crée un objet fonction à partir d'un pointeur vers un membre
(modèle de fonction)
(déprécié en C++11) (supprimé en C++17)
crée un wrapper à partir d'un pointeur vers une fonction membre, appelable avec une référence à l'objet
(modèle de fonction)