如何链接/排队仿函数?

时间:2013-08-23 18:00:16

标签: c++ functor

我没有使用C ++ 11(否则我会使用lambdas)

我有一个输入数据结构和输出数据结构的迭代器。我想对输入数据进行一些操作并将结果存储在输出中。请注意,start和end类型可能不同(例如int - > float)。

我尝试在标准算法之后对我的函数进行建模,并给出了以下原型

template<class INPUT_ITR, OUTPUT_ITR>
void f(INPUT_ITR in_it, INPUT_ITR in_it_end, OUTPUT_ITR out_it, ContextStuff)

根据上下文,该函数可以执行许多不同的操作。有时该函数只需要使用一个仿函数,因此代码行看起来像这样

transform(in_it, in_it_end, out_it, Functor1());

但有时函数想要在每个数据元素上使用一系列仿函数。有没有办法可以创建一个仿函数链作为单个仿函数用于转换?链的仿函数将以编译类型为人所知。

例如

transform(in_it, in_it_end, out_it, CHAIN(Functor1(), Functor2()));

在* in上执行Functor1,然后在结果上执行Functor2,然后在* out中存储。

我可以从unary_function继承我的函子来获得解决方案。

1 个答案:

答案 0 :(得分:2)

试试这个:

template<class Callable1, class Callable2>
struct Chain : public std::unary_function<
    typename Callable2::argument_type, typename Callable1::result_type>
{
    Chain(const Callable1 &f1, const Callable2 &f2) : f1(f1), f2(f2) {}

    typename Callable1::result_type operator () (
           typename Callable2::argument_type param) 
    { 
        return f1(f2(param));
    }
private:
    Callable1 f1;
    Callable2 f2;
};

template<class Callable1, class Callable2>
Chain<Callable1, Callable2> chain(const Callable1 &f1, const Callable2 &f2) {
    return Chain<Callable1, Callable2>(f1, f2);
}

Chain类是一个结合了其他两个仿函数的仿函数。由于它本身是一个unary_function,你应该能够进一步组合它。 chain函数可让您创建Chain实例,而无需担心类型。

用法示例:http://ideone.com/7QpmEU