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 */
constexpr void iter_swap(I1&& i1, I2&& i2) noexcept(/* 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)), sistd::remove_cvref_t<I1>ostd::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_swapencontrada por la búsqueda dependiente de argumento.
- Si la sobrecarga seleccionada no intercambia el valor denotado por
i1ei2, el programa está mal formado, no se requiere diagnóstico.
- de lo contrario,
ranges::swap(*std::forward<I1>(i1), *std::forward<I2>(i2))si tantoI1comoI2modelanindirectly_readabley sistd::iter_reference_t<I1>ystd::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))), siI1eI2modelanstd::indirectly_move_storable<I1, I2>ystd::indirectly_move_storable<I2, I1>, dondeiter_exchange_movees 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;
}
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.
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.
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) |