2

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

我有输入数据结构和输出数据结构的迭代器。我想对输入数据进行一些操作并将结果存储在输出中。请注意,开始和结束类型可能不同(例如 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 继承我的函子以获得解决方案。

4

1 回答 1

3

尝试这个:

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

于 2013-08-23T18:30:48.603 回答