std::mem_fun
| Definido en el archivo de encabezado <functional>
|
||
template< class Res, class T > std::mem_fun_t<Res,T> mem_fun( Res (T::*f)() ); |
(1) | (en desuso en C++11) (eliminado en C++17) |
template< class Res, class T > std::const_mem_fun_t<Res,T> mem_fun( Res (T::*f)() const ); |
(1) | (en desuso en C++11) (eliminado en C++17) |
template< class Res, class T, class Arg > std::mem_fun1_t<Res,T,Arg> mem_fun( Res (T::*f)(Arg) ); |
(2) | (en desuso en C++11) (eliminado 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) | (en desuso en C++11) (eliminado en C++17) |
Crea un objeto envoltorio de función miembro, deduciendo el tipo de objetivo a partir de los argumentos de plantilla. El objeto envoltorio espera un puntero a un objeto de tipo T como primer parámetro a su operator().
std::mem_fun_t<Res,T>(f) o std::const_mem_fun_t<Res,T>(f).std::mem_fun1_t<Res,T,Arg>(f) o std::const_mem_fun1_t<Res,T,Arg>(f).Esta función y los tipos relacionados fueron marcados como en desuso en C++11, y eliminados en C++17, favoreciendo las más generales std::mem_fn y std::bind, las cuales crean objetos invocables compatibles con adaptadores desde funciones miembro.
Parámetros
| f | - | puntero a función miembro de la cual se va a crear el envoltorio |
Valor de retorno
Un objeto invocable que envuelve a f.
Excepciones
Puede lanzar excepciones definidas por la implementación.
Notas
La diferencia entre std::mem_fun y std::mem_fun_ref es que la primera produce un envoltorio que espera un puntero a objeto, mientras que la segunda espera una referencia.
Ejemplo
El siguiente ejemplo demuestra el uso de std::mem_fun y lo compara con std::mem_fn.
Puede requerir un modo de compilación compatible con C++11/14 (p.e. g++/clang++ with -std=c++11, cl with /std:c++11).
#include <iostream>
#include <functional>
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"; }
int data{42};
};
int main() {
S s;
auto p = std::mem_fun(&S::get_data);
std::cout << "s.get_data(): " << p(&s) << '\n';
auto p0 = std::mem_fun(&S::no_args);
p0(&s);
auto p1 = std::mem_fun(&S::one_arg);
p1(&s, 1);
// auto p2 = std::mem_fun(&S::two_args); // Error: mem_fun solo es compatible funciones
// miembro sin parámetros, o con solo un parámetro.
// Por lo tanto, std::mem_fn es mejor alternativa:
auto p2 = std::mem_fn(&S::two_args);
p2(s, 1, 2);
// auto pd = std::mem_fun(&S::data); // Error: no es compatible con punteros a variables
// miembro. Use std::mem_fn en su lugar:
auto pd = std::mem_fn(&S::data);
std::cout << "s.data = " << pd(s) << '\n';
}
Posible salida:
s.get_data(): 42
void S::no_args() const
void S::one_arg(int)
void S::two_args(int, int)
s.data = 42
Ver también
(C++11) |
Crea un objeto función de un puntero a un miembro. (plantilla de función) |
(en desuso en C++11)(eliminado en C++17) |
Crea un envoltorio de un puntero a función miembro, que puede ser llamado con una referencia a un objeto. (plantilla de función) |