binary_function函数用法

本文介绍如何使用C++中的Functor和Adapter模式来简化代码复用,并通过具体示例展示了如何将二元函数适配为一元函数以适应特定算法需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转自:http://blog.youkuaiyun.com/yzm365487848/article/details/5568496

大多数情况,不需要用到binary_function! 

如果你在定义一个二元的functor时,几乎可以不用管这个binary_function。但是如果你使用一些function adapter的时候就需要了,这其实是在实现一种concept. 

比如,定义一个functor,用来给一个vector <double> push_back一个值

C/C++ code
struct inserter { public: void operator()(double n, vector<double> & v) { v.push_back(n); } }; inserter f; vector<dobule> vd; f(1.0, vd);



现在,如果有一个算法,会往容器里追加一些值。例如这样的

C/C++ code
template<typename Functor> void append(Functor f) { double x; while(cin>>x) f(x); }


这时,你的insert就用不上了,因为append的functor只要求一个参数。如果你的inserter本来是一个很复杂的操作,那么如果重写一个就很麻烦。不过有一个简单的办法是再定义一个inserter_adapter

C/C++ code
template<typename Functor> struct inserter_adapter { inserter_adapter(const Functor& f, vector<double>& v) :f_(f), v_(v) {} void operator()(double x) { f_(x, v_); } Functor f_; vector<double>& v_; };



那么在使用的时候就是下面这样。

C/C++ code
inserter f; vector<dobule> vd; inserter_adapter ia(f, vd); append(ia);


--------------------------------------- 
其实使用STL,你完全不用再写一个inserter_adapter,STL中有一个std::binder2nd的function adapter,作用和inserter_adapter一样,是把第二个参数绑定,让二元的函数对象变成一元的,就能符合只需要一个参数的算法。

但是前面定义的inserter这个函数对象不能直接用在std::binder2nd上,它还不符合std::binder2nd的concept。继承一下binary_function就搞定了。

C/C++ code
struct inserter :public std::binary_function<double, vector<double>&, void> //分别是第一个参数,第二个参数,返回值类型 { public: void operator()(double n, vector<double> & v) { v.push_back(n); } }; inserter f; vector<dobule> vd; inserter_adapter ia(f, vd); append(std::bind2nd(f, vd)); //bind2nd帮你创建了一个binder2nd对象



其实符合了binder2nd的concept,就意味着binder2nd知道了你的inserter需要什么样的参数类型,这样就可以帮你传递参数到你的inserter里面去了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值