菜鸟笔记
提升您的技术认知

std::function详解

std::function是一个函数包装模板,可以包装下列这几种可调用元素类型:函数、函数指针、类成员函数指针或任意类型的函数对象(例如定义了operator()操作并拥有函数闭包)。std::function对象可被拷贝和转移,并且可以使用指定的调用特征来直接调用目标元素。当std::function对象未包裹任何实际的可调用元素,调用该std::function对象将抛出std::bad_function_call异常。

看代码可以理解更快:

  • 包装普通函数
#include <iostream>
#include <functional>
using namespace std;

int g_Minus(int i, int j)
{
  
    return i - j;
}

int main()
{
  
    function<int(int, int)> f = g_Minus;
    cout << f(1, 2) << endl;                                            // -1
    return 1;
}
  • 包装模板函数
#include <iostream>
#include <functional>
using namespace std;

template <class T>
T g_Minus(T i, T j)
{
  
    return i - j;
}

int main()
{
  
    function<int(int, int)> f = g_Minus<int>;
    cout << f(1, 2) << endl;                                            // -1
    return 1;
}
  • 包装lambda表达式
#include <iostream>
#include <functional>
using namespace std;

auto g_Minus = [](int i, int j){
   return i - j; };

int main()
{
  
    function<int(int, int)> f = g_Minus;
    cout << f(1, 2) << endl;                                            // -1
    return 1;
}
  • 包装函数对象

非模板类型

#include <iostream>
#include <functional>
using namespace std;

struct Minus
{
  
    int operator() (int i, int j)
    {
  
        return i - j;
    }
};

int main()
{
  
    function<int(int, int)> f = Minus();
    cout << f(1, 2) << endl;                                            // -1
    return 1;
}

模板类型:

#include <iostream>
#include <functional>
using namespace std;

template <class T>
struct Minus
{
  
    T operator() (T i, T j)
    {
  
        return i - j;
    }
};

int main()
{
  
    function<int(int, int)> f = Minus<int>();
    cout << f(1, 2) << endl;                                            // -1
    return 1;
}

- 包装类静态成员函数

非模板类型

#include <iostream>
#include <functional>
using namespace std;

class Math
{
  
public:
    static int Minus(int i, int j)
    {
  
        return i - j;
    }
};

int main()
{
  
    function<int(int, int)> f = &Math::Minus;
    cout << f(1, 2) << endl;                                            // -1
    return 1;
}

模板类型:

#include <iostream>
#include <functional>
using namespace std;

class Math
{
  
public:
    template <class T>
    static T Minus(T i, T j)
    {
  
        return i - j;
    }
};

int main()
{
  
    function<int(int, int)> f = &Math::Minus<int>;
    cout << f(1, 2) << endl;                                            // -1
    return 1;
}
  • 包装类对象成员函数

非模板类型:

#include <iostream>
#include <functional>
using namespace std;

class Math
{
  
public:
    int Minus(int i, int j)
    {
  
        return i - j;
    }
};

int main()
{
  
    Math m;
    function<int(int, int)> f = bind(&Math::Minus, &m, placeholders::_1, placeholders::_2);
    cout << f(1, 2) << endl;                                            // -1
    return 1;
}

模板类型:

#include <iostream>
#include <functional>
using namespace std;

class Math
{
  
public:
    template <class T>
    T Minus(T i, T j)
    {
  
        return i - j;
    }
};

int main()
{
  
    Math m;
    function<int(int, int)> f = bind(&Math::Minus<int>, &m, placeholders::_1, placeholders::_2);
    cout << f(1, 2) << endl;                                            // -1
    return 1;
}