繁体   English   中英

std :: vector及其迭代器作为单个模板typename

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM