名稱空間
變體
操作

C++ 命名要求: ValueSwappable (C++11 起)

來自 cppreference.com
 
 
C++ 命名要求
基本
型別屬性
全庫範圍
ValueSwappable(值可交換)
(C++11)




Container(容器)
容器元素
迭代器 (Iterator)
流 I/O
格式化器
隨機數
併發
Ranges(範圍)
多維檢視
其他

 

此型別的兩個物件可以被解引用,並且可以使用非限定函式呼叫 swap()std::swap 和使用者定義的 swap() 都可見的上下文中交換結果值。

[編輯] 要求

型別 T 是 ValueSwappable,如果

  1. T 滿足 LegacyIterator 要求。
  2. 對於型別 T 的任何可解引用物件 x(即,除結束迭代器之外的任何值),*x 滿足 Swappable 要求。

許多標準庫函式期望它們的引數滿足 ValueSwappable,這意味著每當標準庫執行交換時,它都會使用與 using std::swap; swap(*iter1, *iter2); 等效的程式碼。

[編輯] 示例

#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
}

[編輯] 參閱

指定兩個 indirectly_readable 型別所引用的值可以被交換
(概念) [編輯]