Namensräume
Varianten
Aktionen

std::iterator_traits<std::common_iterator>

Von cppreference.com
 
 
Iterator-Bibliothek
Iterator-Konzepte
Iterator-Primitive
Algorithmus-Konzepte und Hilfsprogramme
Indirekte aufrufbare Konzepte
Gemeinsame Algorithmus-Anforderungen
(C++20)
(C++20)
(C++20)
Dienstprogramme
(C++20)
Iterator-Adapter
Bereichszugriff
(C++11)(C++14)
(C++14)(C++14)  
(C++11)(C++14)
(C++14)(C++14)  
(C++17)(C++20)
(C++17)
(C++17)
 
 
Definiert in Header <iterator>
template< std::input_iterator I, class S >
struct iterator_traits<std::common_iterator<I, S>>;
(seit C++20)

Bietet die einheitliche Schnittstelle für die Eigenschaften des Typs std::common_iterator.

Inhalt

[bearbeiten] Member-Typen

Typname Definition
iterator_concept
iterator_category
(bedingt vorhanden)
value_type std::iter_value_t<I>
difference_type std::iter_difference_t<I>
Zeiger
  • decltype(c.operator->()), wenn dies wohlgeformt ist (wobei c ein lvalue vom Typ const std::common_iterator<I, S> ist).
  • void andernfalls.
Referenz std::iter_reference_t<I>

[bearbeiten] Beispiel

#include <iterator>
#include <type_traits>
#include <vector>
 
int main()
{
    std::vector v{1, 2, 3, 4};
    using CV = std::common_iterator<
                    std::counted_iterator<std::vector<int>::iterator>,
                    std::default_sentinel_t>;
    CV i{std::counted_iterator{v.begin(), 3}};
    using TRCV = std::iterator_traits<decltype(i)>;
    static_assert(std::is_same<TRCV::iterator_concept, std::forward_iterator_tag>());
    static_assert(std::is_same<TRCV::iterator_category, std::forward_iterator_tag>());
    static_assert(std::is_same<TRCV::value_type, int>());
    static_assert(std::is_same<TRCV::difference_type,
                  std::vector<int>::difference_type>());
    static_assert(std::is_same<TRCV::pointer, decltype(i.operator->())>());
    static_assert(std::is_same<TRCV::reference, int&>());
 
    CV s{std::default_sentinel};
    using TRCS = std::iterator_traits<decltype(s)>;
    static_assert(std::is_same<TRCS::iterator_concept, std::forward_iterator_tag>());
    static_assert(std::is_same<TRCS::iterator_category, std::forward_iterator_tag>());
    static_assert(std::is_same<TRCS::value_type, int>());
    static_assert(std::is_same<TRCS::difference_type,
                  std::vector<int>::difference_type>());
    static_assert(std::is_same<TRCS::pointer, decltype(s.operator->())>());
    static_assert(std::is_same<TRCS::reference, int&>());
}

[bearbeiten] Fehlerberichte

Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.

DR angewendet auf Verhalten wie veröffentlicht Korrigiertes Verhalten
LWG 3749 C++20 wenn std::iter_difference_t<I> kein ganzzahliger Typ ist,
iterator_category war std::input_iterator_tag
iterator_category ist
in diesem Fall nicht definiert.

[bearbeiten] Siehe auch

bietet eine einheitliche Schnittstelle zu den Eigenschaften eines Iterators
(Klassenschablone) [bearbeiten]
berechnet den zugehörigen Differenztyp des Typs std::common_iterator
(Klassenvorlagen-Spezialisierung) [bearbeiten]