function 和 bind
c++11 中引入了 std::function
和 std::bind
主要是为了提供更加灵活的函数对象封装和绑定机制。
std::function
std::function
是一个模板类,它可以包装任何可以调用的目标,包括函数指针、函数对象、成员函数指针和 lambda 表达式。它是一个通用的回调机制,允许你以统一的方式处理各种可调用实体。
std::function
的用途包括:
- 回调函数:在需要回调函数的场景中,
std::function
可以作为一个类型安全的回调参数。 - 泛型编程:在泛型算法中,可以使用
std::function
来传递不同的操作,以便在算法内部执行。 - 事件处理:在图形用户界面或游戏开发中,事件处理通常涉及到回调函数,
std::function
可以用来存储和处理这些回调。 - 策略模式:在实现策略模式时,可以使用
std::function
来存储不同的算法或策略,并在运行时选择使用哪一个。
下面是一个使用std::function
的例子:
#include <functional>
#include <iostream>
void print_number(int n) {
std::cout << n << std::endl;
}
int main() {
std::function<void(int)> func = print_number;
func(42); // 调用 print_number 函数
return 0;
}
std::bind
std::bind
是一个函数模板,它可以用来绑定一个函数或成员函数的参数。它返回一个 std::function
对象,该对象可以像普通函数一样被调用。std::bind
允许你提前绑定一些参数,从而创建一个新的可调用对象。
std::bind
的用途包括:
- 偏函数应用:通过绑定一些参数,你可以创建一个新的函数,该函数在调用时只需要剩余的参数。
- 适配器模式:你可以使用
std::bind
来改变函数的签名,使其适应不同的函数调用约定。 - 成员函数绑定:你可以绑定一个成员函数到一个对象上,创建一个可以像普通函数一样被调用的函数对象。
下面是一个使用std::bind
的例子:
#include <functional>
#include <iostream>
void print_sum(int a, int b) {
std::cout << a << " + " << b << " = " << (a + b) << std::endl;
}
int main() {
// 绑定第一个参数为 10
std::function<void(int)> bound_func = std::bind(print_sum, 10, std::placeholders::_1);
bound_func(20); // 调用时只传递第二个参数
return 0;
}
在这个例子中,std::bind
创建了一个新的函数对象 bound_func
,它将 print_sum
函数的第一个参数固定为 10,并且可以通过传递一个参数来调用它。std::placeholders::_1
是一个占位符,表示在调用 bound_func
时传递给它的第一个参数。
#include <iostream>
#include <functional>
using namespace std;
//保存普通函数
void func1(int a)
{
cout << a << endl;
}
//保存成员函数
class A{
public:
A(string name) : name_(name){}
void func3(int i) const {cout <<name_ << ", " << i << endl;}
private:
string name_;
};
int main()
{
cout << "main1 -----------------" << endl;
//1. 保存普通函数
std::function<void(int a)> func1_;
func1_ = func1;
func1_(2); //2
cout << "\n\nmain2 -----------------" << endl;
//2. 保存lambda表达式
std::function<void()> func2_ = [](){cout << "hello lambda" << endl;};
func2_(); //hello world
cout << "\n\nmain3 -----------------" << endl;
//3 保存成员函数
std::function<void(const A&,int)> func3_ = &A::func3;
A a("darren");
func3_(a, 1);
return 0;
}