我有以下问题:
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>
。在代码中我可以找出正确的类型,但我无法在函数声明中弄清楚这一点。
谢谢!
欢迎任何代码改进建议。 :)
答案 0 :(得分: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;
};