Function Adapter(函数适配器)算法
所谓“函数适配器”是可以将仿函数和另一个仿函数(或某个值,或某一个通常函数)结合起来的仿函数。函数适配器声明于中。
预约义的仿函数函数适配器函数
表达式 效果
bind1st(op,value) op(value,param)
bind2nd(op,value) op(param,value)
not1(op) !op(param)
not2(op) !op(param1,param2)
bind1st()
bind1st将一个二元仿函数(例如greater<>)转换为一个一元仿函数。它一般将第二个参数传给“由第一参数指出”的二元仿函数,做为后者的第一个参数。
bind2nd()
bind2nd将一个二元仿函数(例如greater<>)转换为一个一元仿函数。它一般将第二个参数传给“由第一参数指出”的二元仿函数,做为后者的第二个参数。
针对成员函数而设计的函数适配器
表达式 效果
mem_fun_ref(op) 调用op,那是某对象的一个const成员函数
mem_fun(op) 调用op,那是某对象指针的一个const成员函数
之因此须要针对成员函数而设计的函数适配器,那是由于不可能直接把一个成员函数传递给一个算法,例如:设计
for_each(col.begin(),col.end(),&Person::print);
//ERROR:can not call operator() for a member function pointer
问题在于for_each()会针对第三个参数传进来的指针,调用operator(),而不是调用该指针所指的成员函数。因此经过适配器mem_fun_ref将operator()调用动做进行适当转换,就解决了这个问题。
注意:mem_fun_ref和mem_fun调用的函数必须是const。指针
针对通常函数(非成员函数)设计的函数适配器
表达式 效果
ptr_fun(op) op(param)、op(param1,param2)对象