iter_move (std::common_iterator)
|
friend
constexpr
decltype
(
auto
)
iter_move
(
const
std::
common_iterator
&
i
)
noexcept
(
noexcept
(
ranges::
iter_move
(
std::
declval
<
const
I
&
>
(
)
)
)
|
(desde C++20) | |
Convierte el resultado de desreferenciar el iterador subyacente a su tipo de referencia de valor asociado.
El cuerpo de la función es equivalente a: return std :: ranges:: iter_move ( std :: get < I > ( i. var ) ) ; .
Esta función no es visible para la búsqueda no calificada o calificada ordinaria, y solo puede ser encontrada mediante búsqueda dependiente de argumentos cuando std:: common_iterator < I, S > es una clase asociada de los argumentos.
Si
i.
var
no contiene un objeto
I
(es decir, un iterador), el comportamiento es indefinido.
Contenidos |
Parámetros
| i | - | un adaptador de iterador fuente |
Valor de retorno
Una referencia a rvalue o un temporal prvalue.
Complejidad
Constante.
Ejemplo
#include <iomanip> #include <iostream> #include <iterator> #include <string> #include <vector> void print(auto const& rem, auto const& v) { std::cout << rem << '[' << size(v) << "] { "; for (int o{}; auto const& s : v) std::cout << (o++ ? ", " : "") << std::quoted(s); std::cout << " }\n"; } int main() { std::vector<std::string> p{"Andromeda", "Cassiopeia", "Phoenix"}, q; print("p", p); print("q", q); using CTI = std::counted_iterator<std::vector<std::string>::iterator>; using CI = std::common_iterator<CTI, std::default_sentinel_t>; CI last{std::default_sentinel}; for (CI first{{p.begin(), 2}}; first != last; ++first) q.emplace_back(/* ADL */ iter_move(first)); print("p", p); print("q", q); }
Salida posible:
p[3] { "Andromeda", "Cassiopeia", "Phoenix" }
q[0] { }
p[3] { "", "", "Phoenix" }
q[2] { "Andromeda", "Cassiopeia" }
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 3953 | C++20 | el tipo de retorno era std:: iter_rvalue_reference_t < I > | cambiado a decltype ( auto ) |
Véase también
|
(C++20)
|
convierte el resultado de desreferenciar un objeto a su tipo de referencia de valor asociado
(objeto de punto de personalización) |
|
(C++20)
|
convierte el resultado de desreferenciar el iterador subyacente a su tipo de referencia de valor asociado
(función) |
|
(C++11)
|
convierte el argumento a un xvalue
(plantilla de función) |
|
(C++11)
|
convierte el argumento a un xvalue si el constructor de movimiento no lanza excepciones
(plantilla de función) |
|
(C++11)
|
reenvía un argumento de función y utiliza el argumento de plantilla de tipo para preservar su categoría de valor
(plantilla de función) |
|
(C++20)
|
mueve un rango de elementos a una nueva ubicación
(objeto función algoritmo) |
|
(C++20)
|
mueve un rango de elementos a una nueva ubicación en orden inverso
(objeto función algoritmo) |