Namespaces
Variants

C++ named requirements: ValueSwappable (since C++11)

From cppreference.net
C++ named requirements

Два объекта этого типа могут быть разыменованы, и полученные значения могут быть обменены с помощью неквалифицированного вызова функции swap ( ) в контексте, где видны как std::swap , так и пользовательские swap ( ) .

Требования

Тип T является ValueSwappable если

  1. T удовлетворяет требованиям LegacyIterator .
  2. Для любого разыменовываемого объекта x типа T (то есть любого значения, кроме конечного итератора), *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 типа, могут быть обменены
(концепт)