看一段翻译(翻译自cpluscplus.com),翻译的不专业,仅供参考
【std::function】
Function wrapper
该类可以封装任何可以调用类型的元素(例如:函数、函数对象)到一个可拷贝的对象,其类型依赖它的调用标识。
一个function类实例对象能够包装以下任何类型的调用对象
1、函数
2、函数指针
3、成员指针
4、任何类型的函数对象(例如:一个对象,它的类定义了operator())
【std::bind】
template <class Fn, class ... Args>
bind (Fn&& fn, Args&&... args); // simple
template <class Ret, class Fn, class... Args>
bind(Fn&& fn, Args&&... args); // with return type
Biind function arguments
返回一个基于fn的函数对象,其参数依赖于args
每个参数可能依赖于一个值或者一个placeholder
-如果参数依赖于一个值,调用这个函数对象将永远使用这个值
-如果参数依赖于一个placehodler,调用这个函数对象时使用传递给它的参数
调用这个返回对象返回的类型同fn,除非指定了返回类型(上述第二个构造函数)
std::function 和 std::bind 的区别
std::function 函数、函数指针、成员指针、函数对象(它的类定义了operator())
std::bind 函数对象
对象的依赖性
std::function 可没有对象,调用时可以灵活绑到不同对象上
std::bind 必须对象存在
对于设置回调函数,一般都是使用std::bind;
例如c接口设置的回调函数,虽然都是静态或者全局函数的函数指针传递进入,但是之后的param参数一般都是代表一个对象。
扩展:弱回调
对于弱回调,采用的是函数指针std::function 和 std::weak_ptr的方式(参考muduo中的WeakCallback.h)。
使用std::weak_ptr为了确保在调用回调时判断对象是否还存在。
如果弱回调,采用了std::bind的方式;因为std::bind是函数对象的方式,在调用bind的回调函数时,并不知道对象是否还存在。
如果通过将对象的shared_ptr作为bind函数的参数,在调用时即使传进来是有效的shared_ptr指针值,也可能是把对象进行了delete,但是指针没有置NULL。
使用weak_ptr,
首先,不影响外面对象的释放;
其次,在操作对象时,能够对对象是否存在进行判断。