我是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,这将是非常有帮助的。
答案 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;
};