Namespaces
Variants

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

From cppreference.net
Ranges library
Range adaptors
Definiert im Header <ranges>
template < ranges:: range R >
using borrowed_iterator_t = /* siehe unten */ ;
(1) (seit C++20)
template < ranges:: range R >
using borrowed_subrange_t = /* siehe unten */ ;
(2) (seit C++20)
1) std :: ranges:: iterator_t < R > falls R das Konzept borrowed_range modelliert, andernfalls std::ranges::dangling .
2) std :: ranges:: subrange < std :: ranges:: iterator_t < R >> wenn R das Konzept borrowed_range modelliert, andernfalls std::ranges::dangling .

Diese beiden Alias-Templates werden von einigen constrained algorithms verwendet, um die Rückgabe potenziell hängender Iteratoren oder Views zu vermeiden.

Mögliche Implementierung

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>;

Siehe auch

Ein Platzhaltertyp, der anzeigt, dass ein Iterator oder ein subrange nicht zurückgegeben werden sollte, da er verwaist wäre
(Klasse)