Namespaces
Variants

std::ranges:: borrowed_iterator_t, std::ranges:: borrowed_subrange_t

From cppreference.net
Ranges library
Range adaptors
Определено в заголовочном файле <ranges>
template < ranges:: range R >
using borrowed_iterator_t = /* see below */ ;
(1) (начиная с C++20)
template < ranges:: range R >
using borrowed_subrange_t = /* see below */ ;
(2) (начиная с C++20)
1) std :: ranges:: iterator_t < R > если R моделирует borrowed_range , std::ranges::dangling в противном случае.
2) std :: ranges:: subrange < std :: ranges:: iterator_t < R >> если R моделирует borrowed_range , std::ranges::dangling в противном случае.

Эти два шаблона псевдонимов используются некоторыми ограниченными алгоритмами чтобы избежать возврата потенциально висящих итераторов или представлений.

Возможная реализация

borrowed_iterator_t
template< std::ranges::range R >
using borrowed_iterator_t = std::conditional_t<std::ranges::borrowed_range<R>,
    std::ranges::iterator_t<R>, std::ranges::dangling>;
borrowed_subrange_t
template< std::ranges::range R >
using borrowed_subrange_t = std::conditional_t<std::ranges::borrowed_range<R>,
    std::ranges::subrange<std::ranges::iterator_t<R>>, std::ranges::dangling>;

Смотрите также

тип-заполнитель, указывающий, что итератор или subrange не должен возвращаться, так как он будет висячим
(класс)