名前空間
変種
操作

std::input_iterator_tag, std::output_iterator_tag, std::forward_iterator_tag, std::bidirectional_iterator_tag, std::random_access_iterator_tag

提供: cppreference.com
< cpp‎ | iterator
Defined in header <iterator>
struct input_iterator_tag { };
struct output_iterator_tag { };
struct forward_iterator_tag : public input_iterator_tag { };
struct bidirectional_iterator_tag : public forward_iterator_tag { };
struct random_access_iterator_tag : public bidirectional_iterator_tag { };

空クラス型std::input_iterator_tagstd::output_iterator_tagforward_iterator_tagbidirectional_iterator_tag、及びrandom_access_iterator_tagはイテレータのカテゴリに基づいて適切なアルゴリズムを選択するために使用されます。すべてのイテレータ型には、typedefstd::iterator_traits<Iterator>::iterator_categoryが定義され、これらの5つのタグ·タイプのいずれかの別名として利用可能です。

[編集]

イテレータカテゴリタグに基づいてアルゴリズムを選択するための一般的な手法は、ディスパッチャ·ファンクションを使用することです(もしくはstd :: enable_ifです)

#include <iostream>
#include <vector>
#include <list>
#include <iterator>
 
template< class BDIter >
void alg(BDIter, BDIter, std::bidirectional_iterator_tag)
{
    std::cout << "alg() called for bidirectional iterator\n";
}
 
template <class RAIter>
void alg(RAIter, RAIter, std::random_access_iterator_tag)
{
    std::cout << "alg() called for random-access iterator\n";
}
 
template< class Iter >
void alg(Iter first, Iter last)
{
    alg(first, last,
        typename std::iterator_traits<Iter>::iterator_category());
}
 
int main()
{
    std::vector<int> v;
    alg(v.begin(), v.end());
 
    std::list<int> l;
    alg(l.begin(), l.end());
 
//    std::istreambuf_iterator<char> i1(std::cin), i2;
//    alg(i1, i2); // compile error: no matching function for call
}

出力:

alg() called for random-access iterator
alg() called for bidirectional iterator

[編集] 関連項目

基本イテレータ
(クラステンプレート) [edit]
イテレータのプロパティに統一されたインタフェースを提供します
(クラステンプレート) [edit]