Namespaces
Variants

std:: swap (std::basic_string)

From cppreference.net
std::basic_string
Определено в заголовочном файле <string>
template < class CharT, class Traits, class Alloc >

void swap ( std:: basic_string < CharT, Traits, Alloc > & lhs,

std:: basic_string < CharT, Traits, Alloc > & rhs ) ;
(до C++17)
template < class CharT, class Traits, class Alloc >

void swap ( std:: basic_string < CharT, Traits, Alloc > & lhs,

std:: basic_string < CharT, Traits, Alloc > & rhs ) noexcept ( /* see below */ ) ;
(начиная с C++17)
(constexpr начиная с C++20)

Специализирует алгоритм std::swap для std::basic_string . Обменивает содержимое lhs и rhs .

Эквивалентно lhs. swap ( rhs ) .

Содержание

Параметры

lhs, rhs - строки, содержимое которых нужно обменять

Возвращаемое значение

(нет)

Сложность

Константа.

Исключения

noexcept спецификация:
noexcept ( noexcept ( lhs. swap ( rhs ) ) )
(начиная с C++17)

Пример

#include <iostream>
#include <string>
int main()
{
    std::string a = "AAA";
    std::string b = "BBBB";
    std::cout << "Before swap:\n"
                 "a = " << a << "\n"
                 "b = " << b << "\n\n";
    std::swap(a, b);
    std::cout << "After swap:\n"
                 "a = " << a << "\n"
                 "b = " << b << '\n';
}

Вывод:

Before swap:
a = AAA
b = BBBB
After swap:
a = BBBB
b = AAA

Отчеты о дефектах

Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.

DR Применяется к Поведение в опубликованной версии Корректное поведение
LWG 2064 C++11 не-член swap был noexcept и несоответствовал члену swap noexcept удалён

Смотрите также

обменивает содержимое
(публичная функция-член)