iter_swap (std::common_iterator)
|
template
<
std::
indirectly_swappable
<
I
>
I2,
class
S2
>
friend
constexpr
void
|
(начиная с C++20) | |
Обменивает объекты, на которые указывают два базовых итератора. Поведение не определено, если
x
не содержит объект
I
или
y
не содержит объект
I2
(т.е. по крайней мере один из
x
и
y
не содержит итератор).
Тело функции эквивалентно ranges:: iter_swap ( std :: get < I > ( x. var ) , std :: get < I2 > ( y. var ) ) .
Этот шаблон функции не виден для обычного unqualified или qualified lookup , и может быть найден только с помощью argument-dependent lookup , когда std::common_iterator<I,S> является ассоциированным классом аргументов.
Содержание |
Параметры
| x, y | - | итераторы на элементы для обмена |
Возвращаемое значение
(нет)
Сложность
Константа.
Исключения
Пример
#include <algorithm> #include <iostream> #include <iterator> #include <string> #include <vector> int main() { std::vector<std::string> v1{"1", "2", "3", "4", "5"}, v2{"α", "β", "γ", "δ", "ε"}; using CI = std::common_iterator< std::counted_iterator<std::vector<std::string>::iterator>, std::default_sentinel_t >; CI first1{std::counted_iterator{v1.begin(), 3}}; CI first2{std::counted_iterator{v2.begin(), 4}}; CI last{std::default_sentinel}; auto print = [&](auto rem) { std::cout << rem << "v1 = "; std::ranges::copy(v1, std::ostream_iterator<std::string>{std::cout, " "}); std::cout << "\nv2 = "; std::ranges::copy(v2, std::ostream_iterator<std::string>{std::cout, " "}); std::cout << '\n'; }; print("Before iter_swap:\n"); for (; first1 != last && first2 != last; ++first1, ++first2) iter_swap(first1, first2); // ADL print("After iter_swap:\n"); }
Вывод:
Before iter_swap: v1 = 1 2 3 4 5 v2 = α β γ δ ε After iter_swap: v1 = α β γ 4 5 v2 = 1 2 3 δ ε
Отчеты о дефектах
Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| LWG 3574 | C++20 |
variant
был полностью constexpr (P2231R1), но
common_iterator
не был
|
также сделан constexpr |
Смотрите также
|
обменивает значения двух объектов
(шаблон функции) |
|
|
обменивает два диапазона элементов
(шаблон функции) |
|
|
обменивает элементы, на которые указывают два итератора
(шаблон функции) |
|
|
(C++20)
|
обменивает значения, на которые ссылаются два разыменовываемых объекта
(объект точки настройки) |
|
(C++20)
|
обменивает объекты, на которые указывают два базовых итератора
(шаблон функции) |