4

我有以下问题:

template <int N, typename T>
/*what is the return type*/ nviewgetter( T const& t )
{

    typename T::const_iterator it(t.begin());

    typedef BOOST_TYPEOF_TPL(*it) etype;
    typedef typename boost::fusion::result_of::as_nview<etype, N>::type netype;
    std::vector<netype> r;

    while(it!=t.end()){
        r.push_back( boost::fusion::as_nview<N>(*it) );
        it++;
    }

    //return r;
}

预期的是 T 是一个正向序列序列(例如 boost::fusion::vector),我想查看 T 的每个元素中的第 N 个元素。但是,我事先不知道 的类型boost::fusion::vector,例如 boost::fusion::vector<int, double>boost::fusion::vector<int, double, std::string>。在代码中我可以找出正确的类型,但我无法在函数声明中找出这一点。

谢谢 !

也欢迎任何有关代码改进的建议。:)

4

1 回答 1

4

如果您不想写出完整的类型,可以将类型定义移动到单独的模板中,以便在声明函数模板时它们可用;就像是:

template <int N, typename T>
struct nviewgetter_traits
{
    typedef BOOST_TYPEOF_TPL(typename T::value_type) etype;
    typedef typename boost::fusion::result_of::as_nview<etype, N>::type netype;
    typedef std::vector<netype> result_type;

    // Or combine it into a single monstrosity if you prefer:
    // typedef std::vector<
    //    typename boost::fusion::result_of::as_nview<
    //        BOOST_TYPEOF_TPL(typename T::value_type), N
    //    >::type> result_type;
};

template <int N, typename T>
typename nviewgetter_traits<N,T>::result_type nviewgetter(T const & t)
{
    typename nviewgetter_traits<N,T>::result_type r;
    for (auto it = t.begin(); it != t.end(); ++it) {
        r.push_back( boost::fusion::as_nview<N>(*it) );
    }
    return r;
};
于 2011-12-08T13:00:11.747 回答