Difference between revisions of "cpp/named req/ValueSwappable"
From cppreference.com
m (Text replace - "{{concept" to "{{named req") |
Andreas Krug (Talk | contribs) m (fmt, .) |
||
(5 intermediate revisions by 3 users not shown) | |||
Line 1: | Line 1: | ||
− | {{cpp/named req/title|ValueSwappable}} | + | {{cpp/named req/title|ValueSwappable|notes={{mark since c++11}}}} |
{{cpp/named req/navbar}} | {{cpp/named req/navbar}} | ||
Two objects of this type can be dereferenced and the resulting values can be swapped using unqualified function call {{c|swap()}} in the context where both {{lc|std::swap}} and the user-defined {{c|swap()}}s are visible. | Two objects of this type can be dereferenced and the resulting values can be swapped using unqualified function call {{c|swap()}} in the context where both {{lc|std::swap}} and the user-defined {{c|swap()}}s are visible. | ||
===Requirements=== | ===Requirements=== | ||
+ | A type T is {{named req/core|ValueSwappable}} if | ||
− | + | # {{tt|T}} satisfies the {{named req|Iterator}} requirements. | |
+ | # For any dereferenceable object {{tt|x}} of type {{tt|T}} (that is, any value other than the end iterator), {{tt|*x}} satisfies the {{named req|Swappable}} requirements. | ||
− | + | Many standard library functions expect their arguments to satisfy {{named req/core|ValueSwappable}}, which means that any time the standard library performs a swap, it uses the equivalent of {{c|using std::swap; swap(*iter1, *iter2);}}. | |
− | + | ||
− | + | ||
− | Many standard library functions expect their arguments to satisfy {{named req|ValueSwappable}}, which means that any time the standard library performs a swap, it uses the equivalent of {{c|using std::swap; swap(*iter1, *iter2);}}. | + | |
===Example=== | ===Example=== | ||
{{example | {{example | ||
− | + | |code= | |
− | + | ||
− | + | ||
#include <iostream> | #include <iostream> | ||
#include <vector> | #include <vector> | ||
− | class IntVector { | + | class IntVector |
+ | { | ||
std::vector<int> v; | std::vector<int> v; | ||
− | + | // IntVector& operator=(IntVector); // not assignable (C++98 way) | |
− | + | public: | |
− | void swap(IntVector& other) { | + | IntVector& operator=(IntVector) = delete; // not assignable |
+ | void swap(IntVector& other) | ||
+ | { | ||
v.swap(other.v); | v.swap(other.v); | ||
} | } | ||
}; | }; | ||
− | void swap(IntVector& v1, IntVector& v2) { | + | |
+ | void swap(IntVector& v1, IntVector& v2) | ||
+ | { | ||
v1.swap(v2); | v1.swap(v2); | ||
} | } | ||
Line 42: | Line 44: | ||
}} | }} | ||
− | + | ===See also=== | |
− | + | {{dsc begin}} | |
− | + | {{dsc inc|cpp/iterator/dsc indirectly_swappable}} | |
− | + | {{dsc end}} | |
− | + | ||
− | + | {{langlinks|de|es|fr|it|ja|pt|ru|zh}} | |
− | + | ||
− | + |
Latest revision as of 03:11, 9 August 2023
Two objects of this type can be dereferenced and the resulting values can be swapped using unqualified function call swap() in the context where both std::swap and the user-defined swap()s are visible.
[edit] Requirements
A type T is ValueSwappable if
-
T
satisfies the LegacyIterator requirements. - For any dereferenceable object
x
of typeT
(that is, any value other than the end iterator),*x
satisfies the Swappable requirements.
Many standard library functions expect their arguments to satisfy ValueSwappable, which means that any time the standard library performs a swap, it uses the equivalent of using std::swap; swap(*iter1, *iter2);.
[edit] Example
Run this code
#include <iostream> #include <vector> class IntVector { std::vector<int> v; // IntVector& operator=(IntVector); // not assignable (C++98 way) public: IntVector& operator=(IntVector) = delete; // not assignable void swap(IntVector& other) { v.swap(other.v); } }; void swap(IntVector& v1, IntVector& v2) { v1.swap(v2); } int main() { IntVector v1, v2; // IntVector is Swappable, but not MoveAssignable IntVector* p1 = &v1; IntVector* p2 = &v2; // IntVector* is ValueSwappable std::iter_swap(p1, p2); // OK: iter_swap requires ValueSwappable // std::swap(v1, v2); // compiler error! std::swap requires MoveAssignable }
[edit] See also
(C++20) |
specifies that the values referenced by two indirectly_readable types can be swapped (concept) |