Namespaces
Variants

std::basic_const_iterator<Iter>:: operator constant-iterator

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)
template < /*not-a-const-iterator*/ CI >

requires /*constant-iterator*/ < CI > &&
std:: convertible_to < Iter const & , CI >

constexpr operator CI ( ) const & ;
(1) (начиная с C++23)
template < /*not-a-const-iterator*/ CI >

requires /*constant-iterator*/ < CI > &&
std:: convertible_to < Iter, CI >

constexpr operator CI ( ) && ;
(2) (начиная с C++23)

Возвращает преобразованный константный итератор, к которому базовый итератор current может быть явно или неявно преобразован.

CI удовлетворяет экспозиционной концепции /*not-a-const-iterator*/ тогда и только тогда, когда он не является специализацией basic_const_iterator .

Возвращаемое значение

1) current
2) std :: move ( current )

Пример

#include <iterator>
#include <ranges>
#include <vector>
void foo(std::vector<int>::const_iterator) {}
int main()
{
    auto v = std::vector<int>();
    {
        // ranges::cbegin ниже возвращает vector<int>::const_iterator
        auto i1 = std::ranges::cbegin(v);
        foo(i1); // корректно
    }
    auto t = v | std::views::take_while([](int const x) { return x < 100; });
    {
        // ranges::cbegin ниже возвращает basic_const_iterator<vector<int>::iterator>
        auto i2 = std::ranges::cbegin(t);
        foo(i2); // ошибка до P2836R1
    }
}

Отчёты о дефектах

Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.

DR Applied to Behavior as published Correct behavior
P2836R1 C++23 basic_const_iterator не следует конвертируемости своего базового типа предоставлен оператор преобразования