Namespaces
Variants

std::counted_iterator<I>:: operator[]

From cppreference.net
Iterator library
Iterator concepts
Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
Range access
(C++11) (C++14)
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
(C++17)
constexpr decltype ( auto ) operator [ ] ( std:: iter_difference_t < I > n ) const
requires std:: random_access_iterator < I > ;
(seit C++20)

Greift auf das Element an der angegebenen relativen Position zu. Das Verhalten ist undefiniert, wenn n nicht kleiner als die aufgezeichnete Entfernung zum Ende ist.

Inhaltsverzeichnis

Parameter

n - Position relativ zum aktuellen Standort

Rückgabewert

this - > base ( ) [ n ]

Beispiel

#include <array>
#include <iostream>
#include <iterator>
#include <list>
int main()
{
    std::array array{'A', 'B', 'C', 'D', 'E'};
    std::counted_iterator it{array.begin() + 1, /*count:*/ 3};
    for (int i{}; i != it.count(); ++i)
        std::cout << it[i] << ' ';
    std::cout << '\n';
    for (int i{}; i != it.count(); ++i)
        it[i] += ('E' - 'A');
    for (int i{}; i != it.count(); ++i)
        std::cout << it[i] << ' ';
    std::cout << '\n';
    std::list list{'X', 'Y', 'Z', 'W'};
    std::counted_iterator it2{list.begin(), 3};
//  char x = it2[0]; // Error: requirement `random_access_iterator` was not satisfied.
    std::cout << *it2 << '\n'; // OK
}

Ausgabe:

B C D
F G H
X

Siehe auch

greift auf das referenzierte Element zu
(öffentliche Elementfunktion)