[英]std::vector and its iterator as single template typename
为了获得索引生成函数std :: distance(a,b)的“易于记忆”的接口,我提出了更好地区分它的参数的想法(当使用它的基础时vector:vec.begin())通过使用向量及其迭代器调用模板化函数,如:
std::vector<MyType> vect;
std::vector<MyType>::const_iterator iter;
...
...
size_t id = vectorindex_of(iter, vect);
从不混淆论点顺序的理由;-)
上述观点的明确表述将会读到。 喜欢
template <typename T>
inline
size_t vectorindex_of(
typename std::vector<T>::const_iterator iter,
const std::vector<T>& vect ) {
return std::distance( vect.begin(), iter );
}
......虽然有效,但看起来很尴尬。
我希望让模板机制隐式推导出类似(伪代码)的类型:
template <typename T>
inline
size_t vectorindex_of(T::const_iterator iter, const T& vect) {
return std::distance( vect.begin(), iter );
}
......哪个不起作用。 但为什么?
修复很简单:在T::const_iterator iter
之前添加typename
。 这是必需的,因为类模板可能是专用的,并且使用typename
告诉编译器在T::const_iterator
一个类型名称,而不是值或其他东西。
您也可以在不太通用的功能中执行相同的操作。
template <typename T>
inline
std::size_t vectorindex_of(typename T::const_iterator iter, const T& vect) {
return std::distance( vect.begin(), iter );
}
应该工作正常(注意typename
)。 在任何一种情况下都应该推导出模板参数。
您可能还对以“更容易记住”的方式获取向量迭代器的索引感兴趣:
我 - vec.begin()
它与使用随机访问迭代器的指针算法完全相同!
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.