什么是mem_fn类模板

在C++11标准库中,mem_fn类模板用于生成一个可调用对象,用于调用成员函数,它允许对成员函数进行灵活的处理,支持函数指针、成员指针以及函数对象。mem_fn是一个模板类,用于封装成员函数指针和成员指针函数对象,它可以转换成可调用对象,在调用时可以直接使用operator()调用相应的成员函数。

使用mem_fn类模板

要使用mem_fn类模板,首先需要包含头文件,在代码中使用using语句将std命名空间下的mem_fn引入当前命名空间,以便使用其功能。然后可以使用mem_fn模板生成一个可调用对象来调用相应的成员函数。

#include <functional>
#include <iostream>

class Foo {
public:
    void print(int num) {
        std::cout << "打印数字:" << num << std::endl;
    }
};

int main() {
    Foo foo;
    auto memFn = std::mem_fn(&Foo::print);  // 使用mem_fn生成可调用对象
    memFn(foo, 10);  // 调用成员函数print
    return 0;
}

在上面的代码中,我们定义了一个Foo类,其中有一个成员函数print,在主函数中我们创建一个Foo对象foo,然后使用std::mem_fn生成一个可调用对象memFn来调用成员函数print,并传递参数10。

灵活的成员函数调用

使用mem_fn可以实现对成员函数的灵活调用,可以将成员指针、成员函数指针包装成可调用对象,从而可以方便地对成员函数进行调用。mem_fn可以接受不同类型的参数来调用不同类型的成员函数。例如,可以使用mem_fn来调用基类和派生类的成员函数。

#include <functional>
#include <iostream>

class Base {
public:
    virtual void print() {
        std::cout << "Base::print()" << std::endl;
    }
};

class Derived : public Base {
public:
    void print() override {
        std::cout << "Derived::print()" << std::endl;
    }
};

int main() {
    Derived derived;
    Base* basePtr = &derived;
    
    auto memFn = std::mem_fn(&Base::print);
    
    memFn(basePtr);  // 调用基类的print函数
    
    return 0;
}

在上面的代码中,我们定义了一个基类Base和派生类Derived,派生类重写了基类的print函数。在主函数中,我们将派生类对象的指针赋值给基类指针,然后使用mem_fn生成一个可调用对象memFn来调用基类的print函数,实际调用的是派生类的print函数。这样就实现了对不同类型的成员函数的灵活调用。