std::ranges:: borrowed_range, std::ranges:: enable_borrowed_range
|
Definido en el encabezado
<ranges>
|
||
|
template
<
class
R
>
concepto borrowed_range
=
|
(1) | (desde C++20) |
|
template
<
class
R
>
constexpr bool enable_borrowed_range = false ; |
(2) | (desde C++20) |
borrowed_range
define los requisitos de un rango tal que una función puede tomarlo por valor y devolver iteradores obtenidos de él sin peligro de referencias colgantes.
enable_borrowed_range
plantilla de variable se utiliza para indicar si un
range
es un
borrowed_range
. La plantilla principal se define como
false
.
Contenidos |
Requisitos semánticos
Sea
U
igual a
std::
remove_reference_t
<
T
>
si
T
es un tipo de referencia a valor-R (rvalue), y
T
en caso contrario. Dada una variable
u
de tipo
U
,
T
modela
borrowed_range
solo si la validez de los iteradores obtenidos de
u
no está vinculada al tiempo de vida de dicha variable.
Especializaciones
Un programa puede especializar
enable_borrowed_range
a
true
para
tipos definidos por el programa
sin calificación cv que modelen
borrowed_range
, y a
false
para tipos que no lo hagan. Dichas especializaciones deberán ser utilizables en
expresiones constantes
y tener tipo
const
bool
.
Rangos prestados incondicionalmente en la biblioteca estándar
Especializaciones de
enable_borrowed_range
para todas las especializaciones de las siguientes plantillas estándar se definen como
true
:
- std::basic_string_view
- std::span
- std::ranges::subrange
- std::ranges::ref_view
- std::ranges::empty_view
- std::ranges::iota_view
Rangos condicionalmente prestados en la biblioteca estándar
Especialización de
enable_borrowed_range
para los siguientes adaptadores de rango estándar se define como
true
si y solo si
std
::
ranges
::
enable_borrowed_range
<
V
>
es
true
, donde
V
es el tipo de vista subyacente:
| (desde C++23) |
- std::ranges::common_view
- std::ranges::drop_view
- std::ranges::drop_while_view
- std::ranges::elements_view
| (desde C++23) |
| (desde C++23) |
| (desde C++26) |
-
↑
La vista subyacente
Vtambién debe satisfacerforward_range.
|
Las especializaciones de
|
(desde C++23) |
Ejemplo
Demuestra las especializaciones de
enable_borrowed_range
para tipos definidos por el programa. Tales especializaciones protegen contra resultados potencialmente colgantes.
#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 }
Salida:
42 42
Véase también
|
(C++20)
|
un tipo marcador de posición que indica que un iterador o un
subrange
no debería ser devuelto ya que quedaría colgante
(clase) |