std::pair::swap
(1) | ||
void swap( pair& other )noexcept(/* смотрите ниже */); | (начиная с C++11) (до C++20) | |
constexprvoid swap( pair& other )noexcept(/* смотрите ниже */); | (начиная с C++20) | |
constexprvoid swap(const pair& other )constnoexcept(/* смотрите ниже */); | (2) | (начиная с C++23) |
Заменяет first
на other.first
и second
на other.second
, как если бы usingstd::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))&& В приведённом выше выражении идентификатор | (до C++17) |
1) спецификация noexcept: noexcept( std::is_nothrow_swappable_v<first_type>&& 2) спецификация noexcept: noexcept( std::is_nothrow_swappable_v<const first_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;conststd::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 ) |