Boost C++ 库

……世界上最受推崇且设计最专业的 C++ 库项目之一。 Herb SutterAndrei Alexandrescu,《C++ 编码规范

间接迭代器 - Boost C++ 函数库

间接迭代器

作者 David Abrahams, Jeremy Siek, Thomas Witt
联系方式 dave@boost-consulting.com, jsiek@osl.iu.edu, witt@ive.uni-hannover.de
组织 Boost Consulting, 印第安纳大学 Open Systems Lab, 汉诺威大学 运输铁路运营与建设研究所
日期 2006-09-11
版权 Copyright David Abrahams, Jeremy Siek, and Thomas Witt 2003.
摘要 indirect_iterator适配器通过在operator*()内部应用 *额外* 的解引用来适配迭代器。例如,此迭代器适配器使得可以像容器类型(例如list<foo*>)一样查看指针容器(例如list<foo>). indirect_iterator),就好像它是一个容器一样。pointeeandindirect_reference依赖于两个辅助 trait:value_type来为底层迭代器的

indirect_iterator概要

template <
    class Iterator
  , class Value = use_default
  , class CategoryOrTraversal = use_default
  , class Reference = use_default
  , class Difference = use_default
>
class indirect_iterator
{
 public:
    typedef /* see below */ value_type;
    typedef /* see below */ reference;
    typedef /* see below */ pointer;
    typedef /* see below */ difference_type;
    typedef /* see below */ iterator_category;

    indirect_iterator();
    indirect_iterator(Iterator x);

    template <
        class Iterator2, class Value2, class Category2
      , class Reference2, class Difference2
    >
    indirect_iterator(
        indirect_iterator<
             Iterator2, Value2, Category2, Reference2, Difference2
        > const& y
      , typename enable_if_convertible<Iterator2, Iterator>::type* = 0 // exposition
    );

    Iterator const& base() const;
    reference operator*() const;
    indirect_iterator& operator++();
    indirect_iterator& operator--();
private:
   Iterator m_iterator; // exposition
};

不是迭代器提供支持。indirect_iterator的成员类型按照以下伪代码定义,其中Viterator_traits<Iterator>::value_type

if (Value is use_default) then
    typedef remove_const<pointee<V>::type>::type value_type;
else
    typedef remove_const<Value>::type value_type;

if (Reference is use_default) then
    if (Value is use_default) then
        typedef indirect_reference<V>::type reference;
    else
        typedef Value& reference;
else
    typedef Reference reference;

if (Value is use_default) then
    typedef pointee<V>::type* pointer;
else
    typedef Value* pointer;

if (Difference is use_default)
    typedef iterator_traits<Iterator>::difference_type difference_type;
else
    typedef Difference difference_type;

if (CategoryOrTraversal is use_default)
    typedef iterator-category (
        iterator_traversal<Iterator>::type,``reference``,``value_type``
    ) iterator_category;
else
    typedef iterator-category (
        CategoryOrTraversal,``reference``,``value_type``
    ) iterator_category;

indirect_iteratorrequirements

表达式*v,其中v是一个对象,其类型为iterator_traits<Iterator>::value_type应为有效表达式且可转换为reference. Iterator应模拟由iterator_category. , 参考差值指示的遍历概念。应选择value_type, referencedifference_type使得iterator_category.

满足由iterator_traits<Iterator>::value_type指示的要求。[注意:如果参数不是use_default,则value_type成员的默认值推导算法暗示了进一步的要求。]

indirect_iterator模型

除了由iterator_categoryiterator_traversal<indirect_iterator>::type指示的概念外,indirect_iterator的特化模拟了以下概念,其中v是一个对象,其类型为iterator_traits<Iterator>::value_type:

  • 可读迭代器,如果reference(*v)可转换为value_type.
  • 可写迭代器,如果reference(*v) = t是有效表达式(其中t是一个对象,类型为indirect_iterator::value_type)
  • 左值迭代器,如果reference是引用类型。

indirect_iterator<X,V1,C1,R1,D1>indirect_iterator<Y,V2,C2,R2,D2>当且仅当XY.

indirect_iterator操作

除了上面描述的概念所需的操作外,indirect_iterator的特化还提供了以下操作。

indirect_iterator();

要求Iterator必须是默认可构造的。
效果构造一个实例indirect_iterator使用默认构造的m_iterator.

indirect_iterator(Iterator x);

效果构造一个实例indirect_iterator带有m_iterator从...复制构造x.
template <
    class Iterator2, class Value2, unsigned Access, class Traversal
  , class Reference2, class Difference2
>
indirect_iterator(
    indirect_iterator<
         Iterator2, Value2, Access, Traversal, Reference2, Difference2
    > const& y
  , typename enable_if_convertible<Iterator2, Iterator>::type* = 0 // exposition
);
要求Iterator2隐式转换为Iterator.
效果构造一个实例indirect_iteratorm_iterator子对象由...构造y.base().

Iterator const& base() const;

返回m_iterator

reference operator*() const;

返回**m_iterator

indirect_iterator& operator++();

效果++m_iterator
返回*this

indirect_iterator& operator--();

效果--m_iterator
返回*this

示例

此示例展示了如何使用indirect_iterator通过指针数组来访问字符数组。接下来indirect_iterator转换算法配合使用,将字符(递增一)复制到另一个数组中。源迭代器使用的是常量间接迭代器,目标迭代器使用的是可变间接迭代器。示例的最后一部分打印了原始字符数组,但这次使用的是make_indirect_iterator辅助函数,以更简洁的方式表达。

char characters[] = "abcdefg";
const int N = sizeof(characters)/sizeof(char) - 1; // -1 since characters has a null char
char* pointers_to_chars[N];                        // at the end.
for (int i = 0; i < N; ++i)
  pointers_to_chars[i] = &characters[i];

// Example of using indirect_iterator

boost::indirect_iterator<char**, char>
  indirect_first(pointers_to_chars), indirect_last(pointers_to_chars + N);

std::copy(indirect_first, indirect_last, std::ostream_iterator<char>(std::cout, ","));
std::cout << std::endl;


// Example of making mutable and constant indirect iterators

char mutable_characters[N];
char* pointers_to_mutable_chars[N];
for (int j = 0; j < N; ++j)
  pointers_to_mutable_chars[j] = &mutable_characters[j];

boost::indirect_iterator<char* const*> mutable_indirect_first(pointers_to_mutable_chars),
  mutable_indirect_last(pointers_to_mutable_chars + N);
boost::indirect_iterator<char* const*, char const> const_indirect_first(pointers_to_chars),
  const_indirect_last(pointers_to_chars + N);

std::transform(const_indirect_first, const_indirect_last,
               mutable_indirect_first, std::bind1st(std::plus<char>(), 1));

std::copy(mutable_indirect_first, mutable_indirect_last,
          std::ostream_iterator<char>(std::cout, ","));
std::cout << std::endl;


// Example of using make_indirect_iterator()

std::copy(boost::make_indirect_iterator(pointers_to_chars),
          boost::make_indirect_iterator(pointers_to_chars + N),
          std::ostream_iterator<char>(std::cout, ","));
std::cout << std::endl;

找到。输出是

a,b,c,d,e,f,g,
b,c,d,e,f,g,h,
a,b,c,d,e,f,g,

该示例的源代码可以在这里找到。