boost lambda简介

来源:互联网 发布:苹果5 4g网络怎么开启 编辑:程序博客网 时间:2024/04/30 00:55


1, 简介
  有的时候我们实在是很烦写一个function object了. 为了一个简单的目的,
  不得不跳到很远的某一个hpp文件里面去在声明一个function object, ft.
  lambda能帮你去除烦恼.

  btw: lambda并不仅仅为了方便你"写"程序. 它能在代码优化上发挥一定的作用.

2, 使用
  套用一下,
  for_each(x, x+N, std::cout <<_1 * 1.8);
  很简单是吗?

3, 实现

这个东西寒假时候学习过, 所以提上来先写吧.
如果还是从源代码来看他的实现, 我想我又要累个半死了.
所以这次决定偷懒, 我直接从一个简单的实现来说明这
个东西到底是怎么工作的. 这个实现是从blitz作者主页上
的例子剪裁的, 并非我原创, 特此声明!!

首先, 定义一个包装用的类
  template<class A>
  struct DExpr {
   A a_;

   DExpr(const A& x) : a_(x){ }

    double operator()(double x) const
    { return a_(x); }
  };
  显然这个类什么也不会作, 摆在这里的作用类似于一个boost::any
  然后
  struct DExprIdentity {
    DExprIdentity() { }

    double operator()(double x) const
    { return x; }
  }; //Identity, 就当是我们数学概念里面的变量了 ;)
  struct DExprLiteral {
    double value_;

    DExprLiteral(double value)
    { value_ = value; }

    double operator()(double ) const
    { return value_; }
  }; //Literal, 就当是我们数学概念里面的常量吧
  struct DApAdd {
    DApAdd() { }

    static inline double apply(double a, double b)
    { return a+b; }
  }; //这个类里面定义了一个方法apply, 具体实现了加法
  template<class A, class B, class Op>
  struct DBinExprOp {
    A a_;
    B b_;

    DBinExprOp(const A& a, const B& b)
      : a_(a), b_(b)
    { }

    double operator()(double x) const
    { return Op::apply(a_(x), b_(x)); }
  }; //注意这里的用法,^^^^^^^^^^^^^^
  template<class A>
  DExpr<DBinExprOp<DExprLiteral, DExpr<A>, DApAdd> >
  operator+(double x, const DExpr<A>& a)
  {
    typedef DBinExprOp<DExprLiteral, DExpr<A>, DApAdd> ExprT;
    return DExpr<ExprT>(ExprT(DExprLiteral(x),a));
  } //重载了加法
    就是这些了, 假设我们定义了一个DExpr<DExprIdentity> a;
    那么a+1.2就是一个函数对象了(因为他确实有一个operator()函数).
    当我们对a+1.2调用(a+1.2)(3.4)的时候, 其实是调用了
    DApAdd::apply(DExprIdentiry(a)(3.4), DExprLiteral(1.2)(3.4));
     //  注意a构造成一个identity, 所以对它调用(3.4)返回的就是3.4
     //  注意1.2构造成一个Literal, 所以对它调用(3.4)返回的还是1.2
     //  综合起来(a+1.2)(3.4)返回的就是 4.6.