Difference between revisions of "cpp/string/basic string/swap2"
From cppreference.com
< cpp | string | basic string
(merge noexcept) |
m (→Synopsis: ~constexpr since) |
||
(8 intermediate revisions by 4 users not shown) | |||
Line 1: | Line 1: | ||
− | {{cpp/title | swap | + | {{cpp/title|swap{{small|(std::basic_string)}}}} |
{{cpp/string/basic_string/navbar}} | {{cpp/string/basic_string/navbar}} | ||
{{dcl begin}} | {{dcl begin}} | ||
− | {{dcl | | + | {{dcl header|string}} |
+ | {{dcl rev multi | ||
+ | |until1=c++17|dcl1= | ||
template< class CharT, class Traits, class Alloc > | template< class CharT, class Traits, class Alloc > | ||
− | void swap( std::basic_string<CharT, Traits, Alloc> &lhs, | + | void swap( std::basic_string<CharT, Traits, Alloc>& lhs, |
− | std::basic_string<CharT, Traits, Alloc> &rhs ); | + | std::basic_string<CharT, Traits, Alloc>& rhs ); |
− | + | |notes2={{mark constexpr since c++20}}|dcl2= | |
− | {{ | + | |
template< class CharT, class Traits, class Alloc > | template< class CharT, class Traits, class Alloc > | ||
− | void swap( std::basic_string<CharT, Traits, Alloc> &lhs, | + | void swap( std::basic_string<CharT, Traits, Alloc>& lhs, |
− | std::basic_string<CharT, Traits, Alloc> &rhs ) noexcept(/* see below */); | + | std::basic_string<CharT, Traits, Alloc>& rhs ) noexcept(/* see below */); |
}} | }} | ||
{{dcl end}} | {{dcl end}} | ||
− | Specializes the {{lc|std::swap}} algorithm for {{lc|std::basic_string}}. Swaps the contents of {{ | + | Specializes the {{lc|std::swap}} algorithm for {{lc|std::basic_string}}. Swaps the contents of {{c|lhs}} and {{c|rhs}}. |
+ | |||
+ | Equivalent to {{c|lhs.swap(rhs)}}. | ||
===Parameters=== | ===Parameters=== | ||
{{par begin}} | {{par begin}} | ||
− | {{par | lhs, rhs | strings whose contents to swap}} | + | {{par|lhs, rhs|strings whose contents to swap}} |
− | {{par end}} | + | {{par end}} |
===Return value=== | ===Return value=== | ||
Line 27: | Line 30: | ||
Constant. | Constant. | ||
− | {{ | + | {{rrev|since=c++17| |
− | + | ||
===Exceptions=== | ===Exceptions=== | ||
{{noexcept|noexcept(lhs.swap(rhs))}} | {{noexcept|noexcept(lhs.swap(rhs))}} | ||
}} | }} | ||
− | {{ | + | |
+ | ===Example=== | ||
+ | {{example | ||
+ | |code= | ||
+ | #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'; | ||
+ | } | ||
+ | |||
+ | |output= | ||
+ | Before swap: | ||
+ | a = AAA | ||
+ | b = BBBB | ||
+ | |||
+ | After swap: | ||
+ | a = BBBB | ||
+ | b = AAA | ||
+ | }} | ||
+ | |||
+ | ===Defect reports=== | ||
+ | {{dr list begin}} | ||
+ | {{dr list item|wg=lwg|dr=2064|std=C++11|before=non-member {{tt|swap}} was noexcept and inconsistent with member {{tt|swap}}|after=noexcept removed}} | ||
+ | {{dr list end}} | ||
===See also=== | ===See also=== | ||
{{dsc begin}} | {{dsc begin}} | ||
− | {{dsc inc | cpp/string/basic_string/dsc swap}} | + | {{dsc inc|cpp/string/basic_string/dsc swap}} |
{{dsc end}} | {{dsc end}} | ||
− | + | {{langlinks|de|es|fr|it|ja|pt|ru|zh}} | |
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + | ||
− | + |
Latest revision as of 10:47, 18 April 2024
Defined in header <string>
|
||
template< class CharT, class Traits, class Alloc > void swap( std::basic_string<CharT, Traits, Alloc>& lhs, |
(until C++17) | |
template< class CharT, class Traits, class Alloc > void swap( std::basic_string<CharT, Traits, Alloc>& lhs, |
(since C++17) (constexpr since C++20) |
|
Specializes the std::swap algorithm for std::basic_string. Swaps the contents of lhs and rhs.
Equivalent to lhs.swap(rhs).
Contents |
[edit] Parameters
lhs, rhs | - | strings whose contents to swap |
[edit] Return value
(none)
[edit] Complexity
Constant.
Exceptionsnoexcept specification:
noexcept(noexcept(lhs.swap(rhs))) |
(since C++17) |
[edit] Example
Run this code
#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'; }
Output:
Before swap: a = AAA b = BBBB After swap: a = BBBB b = AAA
[edit] Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 2064 | C++11 | non-member swap was noexcept and inconsistent with member swap
|
noexcept removed |
[edit] See also
swaps the contents (public member function) |