std::ranges::iter_swap
Definido en el archivo de encabezado <iterator>
|
||
inline namespace /*sin especificar*/ { inline constexpr /*sin especificar*/ iter_swap = /*sin especificar*/; |
(desde C++20) (objeto punto de personalización) |
|
Signatura de llamada |
||
template< class I1, class I2 > requires /* véase más abajo */ |
||
Intercambia valores denotados por dos iteradores.
Una llamada a ranges::iter_swap
es equivalente en expresión a:
- (void)iter_swap(std::forward<I1>(i1), std::forward<I2>(i2)), si std::remove_cvref_t<I1> o std::remove_cvref_t<I2> es una clase o un tipo enumeración y la expresión está bien formada en un contexto no evaluado, donde la resolución de sobrecarga se lleva a cabo con los siguientes candidatos:
- void iter_swap(auto, auto) = delete;
- cualquier declaración de
iter_swap
encontrada por la búsqueda dependiente de argumento.
- Si la sobrecarga seleccionada no intercambia el valor denotado por
i1
ei2
, el programa está mal formado, no se requiere diagnóstico.
- de lo contrario, ranges::swap(*std::forward<I1>(i1), *std::forward<I2>(i2)) si tanto
I1
comoI2
modelanindirectly_readable
y si std::iter_reference_t<I1> y std::iter_reference_t<I2> modelanswappable_with
. - de lo contrario, (void)(*std::forward<I1>(i1) = /*iter_exchange_move*/(std::forward<I2>(i2), std::forward<I1>(i1))), si
I1
eI2
modelan std::indirectly_move_storable<I1, I2> y std::indirectly_move_storable<I2, I1>, dondeiter_exchange_move
es una plantilla de función de solo exposición descrita posteriormente.
En todos los otros casos, una llamada a ranges::iter_swap
está mal formada, lo que puede resultar en falla en la sustitución cuando ranges::iter_swap(e1, e2) aparece en el contexto inmediato de una instanciación de plantilla.
La plantilla de función de solo exposición iter_exchange_move
está definida equivalentemente como:
template<class X, class Y> constexpr std::iter_value_t<X> /*iter_exchange_move*/(X&& x, Y&& y) noexcept(noexcept(std::iter_value_t<X>(std::move(x)) && noexcept(*x = std::ranges::iter_move(y)))) { std::iter_value_t<X> old(std::ranges::iter_move(x)); *x = std::ranges::iter_move(y); return old; }
[editar] Equivalente en expresión
La expresión e es equivalente-en-expresión a la expresión f, si e y f tienen los mismos efectos, ambas potencialmente lanzan o ambas potencialmente no lanzan (es decir, noexcept (e) == noexcept(f)), y ambas son subexpresiones constantes o ambas no son subexpresiones constantes.
[editar] Objetos de punto de personalización
El nombre ranges::iter_swap
denota un objeto de punto de personalización, que es un objeto función const
de un tipo clase literal semiregular
(denotado, a efectos de exposición, como iter_swap_ftor
). Todos los ejemplares de iter_swap_ftor
son iguales. Por lo tanto, ranges::iter_swap
puede copiarse libremente y sus copias pueden usarse indistintamente.
Dado un conjunto de tipos Args...
, si std::declval<Args>()... cumple con los requerimientos para los argumentos de ranges::iter_swap
mencionado anteriormente, iter_swap_ftor
satisfará a std::invocable<const iter_swap_ftor&, Args...>. De lo contrario, ningún operador de llamada a función de iter_swap_ftor
participa en la resolución de sobrecarga.
[editar] Véase también
(C++20) |
Intercambia los objetos a los que apuntan dos iteradores subyacentes ajustados (plantilla de función) |
(C++20) |
Intercambia los objetos a los que apuntan dos iteradores subyacentes (plantilla de función) |
Intercambia los elementos a los que apuntan dos iteradores (plantilla de función) |