std::ranges:: borrowed_range, std::ranges:: enable_borrowed_range
|
Défini dans l'en-tête
<ranges>
|
||
|
template
<
class
R
>
concept borrowed_range
=
|
(1) | (depuis C++20) |
|
template
<
class
R
>
constexpr bool enable_borrowed_range = false ; |
(2) | (depuis C++20) |
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.
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
:
- std::basic_string_view
- std::span
- std::ranges::subrange
- std::ranges::ref_view
- std::ranges::empty_view
- std::ranges::iota_view
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) |
- std::ranges::common_view
- std::ranges::drop_view
- std::ranges::drop_while_view
- std::ranges::elements_view
| (depuis C++23) |
| (depuis C++23) |
| (depuis C++26) |
-
↑
La vue sous-jacente
Vdoit également satisfaireforward_range.
|
Les spécialisations de
|
(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
|
(C++20)
|
un type de substitution indiquant qu'un itérateur ou un
subrange
ne devrait pas être retourné car il serait suspendu
(classe) |