iterator_trait的典型用例是什么?

时间:2011-07-19 03:30:32

标签: c++ stl iterator traits iterator-traits

我是C ++的新手,所以请耐心等待。我想了解STL iterator_traits。在“C ++标准库”一书中,iterator_traits结构定义如下:

template <class T>
struct iterator_traits{
  typedef typename T::value_type value_type
  typedef typename T::difference_type difference_type
  typedef typename T::iterator_category iterator_category
  typedef typename T::pointer pointer
  typedef typename T::reference reference
}

所以在我看来,它正在重新暴露T已经暴露的子类型。继续前进,本书给出了如何使用它的示例,类似于以下

template <class MyIterator>
void do_something(MyIterator start, MyIterator end) {
    typedef typename iterator_traits<MyIterator>::value_type value_type
    value_type v = *start
    .....

我的问题是为什么我在这里需要这个iterator_traits结构,如果想要获得value_type,我不能直接从MyIterator获得它吗?我的困惑似乎来自于我(肯定是不正确的)理解,即子类型的信息必须来自用于实例化iterator_trait的template <class T>。所以如果你能解释一下,最好用一个例子说明为什么以及在哪里我需要iterator_traits,这将是非常有帮助的。

1 个答案:

答案 0 :(得分:21)

指向数组的指针可用作随机访问迭代器。

需要有一些一致的方法来获取这些类型的指针(显然不能将类型声明为嵌套类型,因为只有类可以有嵌套类型)和类型类型迭代器。 traits类模板提供了这种一致的方式。

iterator_traits类模板专门用于指针:

template <typename T>
struct iterator_traits<T*>
{
    typedef std::random_access_iterator_tag iterator_category;
    typedef T                               value_type;
    typedef T*                              pointer;
    typedef T&                              reference;
    typedef std::ptrdiff_t                  difference_type;
};