std::basic_string<CharT,Traits,Allocator>::swap
Материал из cppreference.com
<tbody>
</tbody>
<tbody class="t-dcl-rev ">
</tbody><tbody>
</tbody>
void swap( basic_string& other ); |
(до C++17) | |
void swap( basic_string& other ) noexcept(/* смотрите ниже */); |
(начиная с C++17) (до C++20) |
|
constexpr void swap( basic_string& other ) noexcept(/* смотрите ниже */); |
(начиная с C++20) | |
Заменяет содержимое строки на содержимое other. Все итераторы и ссылки могут быть признаны недействительными.
|
Поведение не определено, если |
(начиная с C++11) |
Параметры
| other | — | строка для обмена содержимым |
Возвращаемое значение
(нет)
Сложность
Константная.
Исключения
|
Исключение не генерируется. |
(до C++11) |
|
Исключения могут быть сгенерированы только в том случае, если поведение не определено (смотрите выше). Если по какой-либо причине генерируется исключение, эта функция не имеет эффекта (строгая гарантия безопасности исключений). |
(начиная с C++11) |
|
спецификация noexcept:
noexcept(std::allocator_traits<Allocator>::propagate_on_container_swap::value || std::allocator_traits<Allocator>::is_always_equal::value) |
(начиная с C++17) |
Пример
Запустить этот код
#include <iostream>
#include <string>
int main()
{
std::string a = "AAA";
std::string b = "BBBB";
std::cout << "Перед swap:\n"
"a = " << a << "\n"
"b = " << b << "\n\n";
a.swap(b);
std::cout << "После swap:\n"
"a = " << a << "\n"
"b = " << b << '\n';
}
Вывод:
Перед swap:
a = AAA
b = BBBB
После swap:
a = BBBB
b = AAA
Отчёты о дефектах
Следующие изменения поведения были применены с обратной силой к ранее опубликованным стандартам C++:
| Номер | Применён | Поведение в стандарте | Корректное поведение |
|---|---|---|---|
| LWG 403 | C++98 | swap() может вызвать исключение
|
исключение не генерируется |
| LWG 535 | C++98 | замена строк не сохраняла порядок символов | порядок также сохраняется |
Смотрите также
| меняет местами значения двух объектов (шаблон функции) | |
| меняет местами два диапазона элементов (шаблон функции) | |
(C++17) |
обменивает содержимое (public функция-элемент std::basic_string_view<CharT,Traits>)
|