std::ranges:: borrowed_range, std::ranges:: enable_borrowed_range
|
Definiert im Header
<ranges>
|
||
|
template
<
class
R
>
concept borrowed_range
=
|
(1) | (seit C++20) |
|
template
<
class
R
>
constexpr bool enable_borrowed_range = false ; |
(2) | (seit C++20) |
borrowed_range
definiert die Anforderungen eines Ranges, sodass eine Funktion ihn als Wert übernehmen und von ihm erhaltene Iteratoren zurückgeben kann, ohne Gefahr von Dangling-Zeigern.
enable_borrowed_range
Variable Template wird verwendet, um anzuzeigen, ob ein
range
ein
borrowed_range
ist. Das primäre Template ist als
false
definiert.
Inhaltsverzeichnis |
Semantische Anforderungen
Sei
U
gleich
std::
remove_reference_t
<
T
>
falls
T
ein Rvalue-Referenztyp ist, andernfalls gleich
T
. Für eine Variable
u
vom Typ
U
modelliert
T
borrowed_range
nur dann, wenn die Gültigkeit der von
u
erhaltenen Iteratoren nicht an die Lebensdauer dieser Variable gebunden ist.
Spezialisierungen
Ein Programm kann
enable_borrowed_range
für cv-unqualifizierte
programmdefinierte Typen
, die
borrowed_range
modellieren, auf
true
spezialisieren und für Typen, die dies nicht tun, auf
false
. Solche Spezialisierungen müssen in
konstanten Ausdrücken
verwendbar sein und den Typ
const
bool
haben.
Unbedingt entliehene Ranges in der Standardbibliothek
Spezialisierungen von
enable_borrowed_range
für alle Spezialisierungen der folgenden Standardtemplates sind als
true
definiert:
- std::basic_string_view
- std::span
- std::ranges::subrange
- std::ranges::ref_view
- std::ranges::empty_view
- std::ranges::iota_view
Bedingt entlehnte Ranges in der Standardbibliothek
Spezialisierung von
enable_borrowed_range
für die folgenden Standard-Range-Adapter sind als
true
definiert genau dann wenn
std
::
ranges
::
enable_borrowed_range
<
V
>
true
ist, wobei
V
der zugrundeliegende View-Typ ist:
| (seit C++23) |
- std::ranges::common_view
- std::ranges::drop_view
- std::ranges::drop_while_view
- std::ranges::elements_view
| (seit C++23) |
| (seit C++23) |
| (seit C++26) |
-
↑
Die zugrunde liegende Ansicht
Vmuss ebenfallsforward_rangeerfüllen.
|
Spezialisierungen von
|
(seit C++23) |
Beispiel
Demonstriert die Spezialisierungen von
enable_borrowed_range
für programmdefinierte Typen. Solche Spezialisierungen schützen vor potenziell hängenden Ergebnissen.
#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; // Kompilierungsfehler (d.h. Schutz vor hängenden Zeigern funktioniert.) 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 }
Ausgabe:
42 42
Siehe auch
|
(C++20)
|
Ein Platzhaltertyp, der anzeigt, dass ein Iterator oder ein
subrange
nicht zurückgegeben werden sollte, da er verwaist wäre
(Klasse) |