std::ranges:: lazy_split_view<V, Pattern>:: inner_iterator
|
template
<
bool
Const
>
struct /*inner_iterator*/ ; |
(desde C++20)
( solo para exposición* ) |
|
El tipo de retorno de
lazy_split_view::
outer_iterator
::
value_type
::
begin
(
)
.
Const
coincide con el argumento de plantilla de
outer_iterator
.
Tipos de miembros
| Miembro | Definición |
Base
|
maybe-const
<
Const, V
>
( tipo de miembro solo para exposición* ) |
iterator_concept
|
|
iterator_category
(condicionalmente presente) |
Presente solo si
|
value_type
|
ranges:: range_value_t < Base > |
difference_type
|
ranges:: range_difference_t < Base > |
Miembros de datos
| Miembro | Descripción |
outer_iterator
<
Const
>
i_
(privado)
|
un iterador hacia la
view
subyacente del objeto padre
lazy_split_view
( objeto miembro solo para exposición* ) |
bool
incremented_
(privado)
|
una bandera que indica si el
operator
++
fue invocado en este objeto al menos una vez
( objeto miembro solo para exposición* ) |
Funciones miembro
|
(constructor)
(C++20)
|
construye un iterador
(función miembro pública) |
|
base
(C++20)
|
devuelve el iterador subyacente
(función miembro pública) |
|
operator*
(C++20)
|
devuelve el elemento actual
(función miembro pública) |
|
operator++
operator++
(int)
(C++20)
|
avanza el iterador
(función miembro pública) |
Funciones miembro
std::ranges::lazy_split_view:: inner_iterator :: inner_iterator
|
/*inner_iterator*/
(
)
=
default
;
|
(1) | (desde C++20) |
|
constexpr
explicit
/*inner_iterator*/
(
/*outer_iterator*/
<
Const
>
i
)
;
|
(2) | (desde C++20) |
i_
mediante su inicializador de miembro predeterminado (=
/*outer_iterator*/
<
Const
>
(
)
).
El miembro de datos
incremented_
se inicializa con su inicializador de miembro predeterminado a
false
.
std::ranges::lazy_split_view:: inner_iterator :: base
|
constexpr
const
ranges::
iterator_t
<
Base
>
&
base
(
)
const
&
noexcept
;
|
(1) | (desde C++20) |
|
constexpr
ranges::
iterator_t
<
Base
>
base
(
)
&&
requires ranges:: forward_range < V > ; |
(2) | (desde C++20) |
Devuelve una copia del iterador subyacente.
std::ranges::lazy_split_view:: inner_iterator :: operator*
|
constexpr
decltype
(
auto
)
operator
*
(
)
const
;
|
(desde C++20) | |
Devuelve el elemento al que apunta el iterador subyacente.
Equivalente a return * i_. /*cur*/ ( ) ; .
std::ranges::lazy_split_view:: inner_iterator :: operador++
|
constexpr
/*inner_iterator*/
&
operator
++
(
)
;
|
(1) | (desde C++20) |
|
constexpr
decltype
(
auto
)
operator
++
(
int
)
;
|
(2) | (desde C++20) |
incremented_ = true ;
if
constexpr
(
!
ranges::
forward_range
<
Base
>
)
{
if
constexpr
(
Pattern
::
size
(
)
==
0
)
return
*
this
;
}
++
i_.
/*cur*/
(
)
;
if constexpr ( ranges:: forward_range < Base > )
{
auto
tmp
=
*
this
;
++*
this
;
return
tmp
;
}
else
++*
this
;
// no hay sentencia return
Funciones no miembro
|
operator==
(C++20)
|
compara los iteradores o el iterador y
std::default_sentinel
(función) |
|
iter_move
(C++20)
|
convierte el resultado de desreferenciar el iterador subyacente a su tipo de referencia de valor asociado
(función) |
|
iter_swap
(C++20)
|
intercambia los objetos apuntados por dos iteradores subyacentes
(función) |
operator== (std::ranges::split_view:: inner_iterator )
|
friend
constexpr
bool
operator
==
(
const
/*inner_iterator*/
&
x,
const
/*inner_iterator*/
&
y
)
|
(1) | (desde C++20) |
|
friend
constexpr
bool
operator
==
(
const
/*inner_iterator*/
&
x,
std:: default_sentinel_t ) ; |
(2) | (desde C++20) |
auto [pcur, pend] = ranges::subrange{x.i_.parent_->pattern_}; auto end = ranges::end(x.i_.parent_->base_); if constexpr (/*tiny_range*/<Pattern>) { const auto& cur = x.i_./*cur*/(); if (cur == end) return true; if (pcur == pend) return x.incremented_; return *cur == *pcur; } else { auto cur = x.i_./*cur*/(); if (cur == end) return true; if (pcur == pend) return x.incremented_; do { if (*cur != *pcur) return false; if (++pcur == pend) return true; } while (++cur != end); return false; }
El operador
!=
es
sintetizado
a partir de
operator==
.
Estas funciones no son visibles para la
búsqueda no calificada
ordinaria o la
búsqueda calificada
, y solo pueden encontrarse mediante
búsqueda dependiente de argumentos
cuando
std::ranges::split_view::
inner_iterator
es una clase asociada de los argumentos.
iter_move (std::ranges::split_view:: inner_iterator )
|
friend
constexpr
decltype
(
auto
)
iter_move
(
const
/*inner_iterator*/
&
i
)
noexcept ( noexcept ( ranges:: iter_move ( i. i_ . /*cur*/ ( ) ) ) ) ; |
(desde C++20) | |
Equivalente a return ranges:: iter_move ( i. i_ . /*cur*/ ( ) ) ; .
Esta función no es visible para la
búsqueda no calificada
ordinaria o la
búsqueda calificada
, y solo puede ser encontrada mediante
búsqueda dependiente de argumentos
cuando
std::ranges::split_view::
inner_iterator
es una clase asociada de los argumentos.
iter_swap (std::ranges::split_view:: inner_iterator )
|
friend
constexpr
void
iter_swap
(
const
/*inner_iterator*/
&
x,
const
/*inner_iterator*/
&
y
)
|
(desde C++20) | |
Equivalente a ranges:: iter_swap ( x. i_ . /*cur*/ ( ) , y. i_ . /*cur*/ ( ) ) .
Esta función no es visible para la
búsqueda no calificada
ordinaria o
búsqueda calificada
, y solo puede ser encontrada mediante
búsqueda dependiente de argumentos
cuando
std::ranges::split_view::
inner_iterator
es una clase asociada de los argumentos.
Informes de defectos
Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares publicados anteriormente de C++.
| DR | Aplicado a | Comportamiento publicado | Comportamiento correcto |
|---|---|---|---|
| LWG 3591 | C++20 |
la sobrecarga
&&
de
base
podría invalidar iteradores externos
|
se añadieron restricciones |
| LWG 3593 | C++20 |
la sobrecarga
const
&
de
base
devuelve una referencia pero podría no ser noexcept
|
se hizo noexcept |