std::pair::swap
Материал из cppreference.com
<tbody>
</tbody>
<tbody class="t-dcl-rev t-dcl-rev-num ">
</tbody><tbody>
</tbody>
| (1) | ||
void swap( pair& other ) noexcept(/* смотрите ниже */); |
(начиная с C++11) (до C++20) |
|
constexpr void swap( pair& other ) noexcept(/* смотрите ниже */); |
(начиная с C++20) | |
constexpr void swap( const pair& other ) const noexcept(/* смотрите ниже */); |
(2) | (начиная с C++23) |
Заменяет first на other.first и second на other.second, как если бы using std::swap; swap(first, other.first); swap(second, other.second);.
|
Если выбранный вызов функции |
(до C++23) |
|
1) Программа некорректна, если либо
std::is_swappable_v<T1>, либо std::is_swappable_v<T2> не равно true.2) Программа некорректна, если либо
std::is_swappable_v<const T1>, либо std::is_swappable_v<const T2> не равно true.Если выбранный вызов функции |
(начиная с C++23) |
Параметры
| other | — | pair значений для обмена |
Возвращаемое значение
(нет)
Исключения
|
спецификация noexcept:
noexcept( noexcept(swap(first, other.first)) && noexcept(swap(second, other.second)) )В приведённом выше выражении идентификатор |
(до C++17) |
|
1)
спецификация noexcept:
noexcept( std::is_nothrow_swappable_v<first_type> && std::is_nothrow_swappable_v<second_type> )2) спецификация noexcept:
noexcept( std::is_nothrow_swappable_v<const first_type> && std::is_nothrow_swappable_v<const second_type> ) |
(начиная с C++17) |
Пример
Запустить этот код
#include <iostream>
#include <utility>
#include <string>
int main()
{
std::pair<int, std::string> p1(10, "тест"), p2;
p2.swap(p1);
std::cout << "(" << p2.first << ", " << p2.second << ")\n";
#if __cpp_lib_ranges_zip >= 202110L
// Используется перегрузка C++23 const квалифицированной swap
// (swap больше не распространяет константность pair)
int i1 = 10, i2{};
std::string s1("тест"), s2;
const std::pair<int&, std::string&> r1(i1, s1), r2(i2, s2);
r2.swap(r1);
std::cout << "(" << i2 << ", " << s2 << ")\n";
#endif
}
Возможный вывод:
(10, тест)
(10, тест)
Отчёты о дефектах
Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:
| Номер | Применён | Поведение в стандарте | Корректное поведение |
|---|---|---|---|
| LWG 2456 | C++11 | спецификация noexcept некорректна
|
сделана работающей |
Смотрите также
| меняет местами значения двух объектов (шаблон функции) | |
меняет местами содержимое двух tuple (public функция-элемент std::tuple)
|