Namespaces
Variants

std::ranges:: borrowed_range, std::ranges:: enable_borrowed_range

From cppreference.net
Ranges library
Range adaptors
Défini dans l'en-tête <ranges>
template < class R >

concept borrowed_range =
ranges:: range < R > &&
( std:: is_lvalue_reference_v < R > ||

ranges :: enable_borrowed_range < std:: remove_cvref_t < R >> ) ;
(1) (depuis C++20)
template < class R >
constexpr bool enable_borrowed_range = false ;
(2) (depuis C++20)
1) Le concept borrowed_range définit les exigences d'un intervalle tel qu'une fonction puisse le prendre par valeur et retourner des itérateurs obtenus à partir de celui-ci sans risque de références pendantes.
2) La variable template enable_borrowed_range est utilisée pour indiquer si un range est un borrowed_range . Le template primaire est défini comme false .

Table des matières

Exigences sémantiques

Soit U le type std:: remove_reference_t < T > si T est un type de référence rvalue, et T sinon. Étant donné une variable u de type U , T modélise borrowed_range seulement si la validité des itérateurs obtenus à partir de u n'est pas liée à la durée de vie de cette variable.

Spécialisations

Un programme peut spécialiser enable_borrowed_range à true pour les types définis par le programme non qualifiés cv qui modélisent borrowed_range , et à false pour les types qui ne le modélisent pas. Ces spécialisations doivent être utilisables dans les expressions constantes et avoir le type const bool .

Plages empruntées inconditionnellement dans la bibliothèque standard

Les spécialisations de enable_borrowed_range pour toutes les spécialisations des modèles standards suivants sont définies comme true :

Plages conditionnellement empruntées dans la bibliothèque standard

Spécialisation de enable_borrowed_range pour les adaptateurs de plage standard suivants est définie comme true si et seulement si std :: ranges :: enable_borrowed_range < V > est true , où V est le type de vue sous-jacent :

(depuis C++23)
(depuis C++23)
(depuis C++23)
(depuis C++26)
  1. La vue sous-jacente V doit également satisfaire forward_range .

Les spécialisations de enable_borrowed_range pour les adaptateurs de plage standard suivants sont définies comme true si et seulement si ( std :: ranges :: enable_borrowed_range < Vs > && ... ) est true , où Vs... sont tous les types de vue qu'il adapte :

(depuis C++23)

Exemple

Démontre les spécialisations de enable_borrowed_range pour les types définis par le programme. De telles spécialisations protègent contre les résultats potentiellement pendants.

#include <algorithm>
#include <array>
#include <cstddef>
#include <iostream>
#include <ranges>
#include <span>
#include <type_traits>
template<typename T, std::size_t N>
struct MyRange : std::array<T, N> {};
template<typename T, std::size_t N>
constexpr bool std::ranges::enable_borrowed_range<MyRange<T, N>> = false;
template<typename T, std::size_t N>
struct MyBorrowedRange : std::span<T, N> {};
template<typename T, std::size_t N>
constexpr bool std::ranges::enable_borrowed_range<MyBorrowedRange<T, N>> = true;
int main()
{
    static_assert(std::ranges::range<MyRange<int, 8>>);
    static_assert(std::ranges::borrowed_range<MyRange<int, 8>> == false);
    static_assert(std::ranges::range<MyBorrowedRange<int, 8>>);
    static_assert(std::ranges::borrowed_range<MyBorrowedRange<int, 8>> == true);
    auto getMyRangeByValue = []{ return MyRange<int, 4>{{1, 2, 42, 3}}; };
    auto dangling_iter = std::ranges::max_element(getMyRangeByValue());
    static_assert(std::is_same_v<std::ranges::dangling, decltype(dangling_iter)>);
    // *dangling_iter; // compilation error (i.e. dangling protection works.)
    auto my = MyRange<int, 4>{{1, 2, 42, 3}};
    auto valid_iter = std::ranges::max_element(my);
    std::cout << *valid_iter << ' '; // OK: 42
    auto getMyBorrowedRangeByValue = []
    {
        static int sa[4]{1, 2, 42, 3};
        return MyBorrowedRange<int, std::size(sa)>{sa};
    };
    auto valid_iter2 = std::ranges::max_element(getMyBorrowedRangeByValue());
    std::cout << *valid_iter2 << '\n'; // OK: 42
}

Sortie :

42 42

Voir aussi

un type de substitution indiquant qu'un itérateur ou un subrange ne devrait pas être retourné car il serait suspendu
(classe)