本文主要是介绍函数配接器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
STL中的函数配接器,是指能够将仿函数和另一个仿函数或某个值或某一个一般函数结合起来形成一个新的仿函数。
在STL中函数配接器一共有四个,分别是:
bind1nd(op ,value) 相当于构成op(value,param),即把value结合成op的第一个参数
bind2nd(op ,value) 相当于构成op(param,value),即把value结合成op的第二个参数
not1(op) 相当于构成!op(param),即op(param)的结果进行逻辑非运算
not2(op) 相当于构成!op(param,param),即把op(param,param)的结构进行逻辑非运算
下面先以bind2nd为例示例:
#include<iostream>
#include<vector>
#include<algorithm>
#include<iterator>
#include<functional>
using namespace std;class A :public binary_function<int,int,void>
{
public:A(){}~A(){}void operator()( int a, int b) const{ostream_iterator<int> os(cout,"--");*os = a + b;}
private:
};void fun(int a,int b)
{ostream_iterator<int> os(cout,"--");*os = a + b;
}int Get(int a)
{return a;
}
int main()
{vector<int> B;for(int i = 0;i<5;i++) B.push_back(i);//bind2nd将一个仿函数和一个数值结合for_each(B.begin(), B.end(), bind2nd(A(),2));cout<<endl;//先用ptr_fun把一个普通函数适配成一个仿函数,再用bind2nd将之与常数结合for_each(B.begin(), B.end(), bind2nd(ptr_fun(fun),1));cout<<endl;//bind2nd将一个仿函数与普通函数结合for_each(B.begin(), B.end(), bind2nd(A(),Get(3)));
}
注意在使用中注意一下几点:
一、在自己编写适用于bind2nd或bind1nd的仿函数时,该仿函数类必须继承于类binary_function(T(第一个参数类型),T(第二个参数类型),T(返回值类型))。
二、对于普通函数也需要用函数配接器结合时,需要先用ptr_fun()封装(对于ptr_fun的讲解在http://blog.csdn.net/yyc1023/article/details/38498325)。
至于其他的几个配接器的用法类似即可。
这篇关于函数配接器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!