binary_function的用处(转)

大多数情况,不需要用到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里面去了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值