std::ranges:: cbegin
|
Definido en el encabezado
<ranges>
|
||
|
Definido en el encabezado
<iterator>
|
||
|
inline
namespace
/* unspecified */
{
inline
constexpr
/* unspecified */
cbegin
=
/* unspecified */
;
|
(desde C++20)
(objeto de punto de personalización) |
|
|
Firma de llamada
|
||
|
template
<
class
T
>
requires
/* see below */
|
(desde C++20) | |
|
Devuelve un iterador al primer elemento del argumento calificado como const. |
(until C++23) |
|
Devuelve un iterador constante al primer elemento del argumento. |
(since C++23) |
|
Sea
Una llamada a
|
(hasta C++23) |
|
Si el argumento es un lvalue o
ranges::
enable_borrowed_range
<
std::
remove_cv_t
<
T
>>
es
true
, entonces una llamada a
En todos los demás casos, una llamada a
|
(desde C++23) |
El tipo de retorno modela
std::input_or_output_iterator
y
constant-iterator
(desde C++23)
en todos los casos.
Contenidos |
Objetos de punto de personalización
El nombre
ranges::cbegin
denota un
objeto de punto de personalización
, que es un
objeto función
constante de un tipo de clase
literal
semiregular
. Consulte
CustomizationPointObject
para más detalles.
Notas
Para un rango lvalue e de tipo T , ranges :: cbegin ( e ) es equivalente a
|
ranges:: begin ( std:: as_const ( e ) ) . |
(hasta C++23) |
|
(desde C++23) |
Ejemplo
#include <cassert> #include <ranges> #include <vector> int main() { std::vector v{3, 1, 4}; auto vi = std::ranges::cbegin(v); assert(3 == *vi); ++vi; // OK, el objeto iterador constante es mutable assert(1 == *vi); // *vi = 13; // Error: el iterador constante apunta a un elemento inmutable int a[]{3, 1, 4}; auto ai = std::ranges::cbegin(a); // cbegin también funciona con arrays de C assert(3 == *ai and *(ai + 1) == 1); // *ai = 13; // Error: la variable de solo lectura no es asignable }
Véase también
|
(C++20)
|
devuelve un iterador al inicio de un rango
(objeto de punto de personalización) |
|
(C++11)
(C++14)
|
devuelve un iterador al inicio de un contenedor o array
(plantilla de función) |