C++官网参考里链接:https://cplusplus.com/reference/deque/deque/swap-free/
函数模板
<deque>
std::swap (deque)
template <class T, class Alloc> void swap (deque<T,Alloc>& x, deque<T,Alloc>& y);
交换两个双端队列容器的内容
容器x的内容与容器y的内容交换。两个容器对象必须具有相同的类型(相同的模板形参),尽管大小可能不同。
在调用这个成员函数之后,x中的元素是调用之前在y中的元素,y中的元素是在x中的元素。所有迭代器、引用和指针对于交换后的对象仍然有效。
这是通用算法swap的重载,通过将资产的所有权相互转移到另一个容器(即,容器交换对其数据的引用,而不实际执行任何元素复制或移动)来提高性能:它的行为就像调用了x.swap(y)。
形参
x, y
deque相同类型的容器(即具有相同的模板形参,T和Alloc)。
返回值
没有返回值。
用例
// swap (deque overload)
#include <iostream>
#include <deque>
main ()
{
unsigned int i;
std::deque<int> foo (3,100); // three ints with a value of 100
std::deque<int> bar (5,200); // five ints with a value of 200
swap(foo,bar);
std::cout << "foo contains:";
for (std::deque<int>::iterator it = foo.begin(); it!=foo.end(); ++it)
std::cout << ' ' << *it;
std::cout << '\n';
std::cout << "bar contains:";
for (std::deque<int>::iterator it = bar.begin(); it!=bar.end(); ++it)
std::cout << ' ' << *it;
std::cout << '\n';
return 0;
}
输出:
复杂性
常数。
迭代器的有效性
所有指向两个容器中元素的迭代器、指针和引用仍然有效,现在指向的是它们在调用之前引用的相同元素,但在另一个容器中,它们现在进行迭代的地方。
注意,结束迭代器不指向元素,可能会无效。
数据竞争
两个容器x和y都被修改了。
异常安全
如果两个比较比较中的分配器相等,或者它们的分配器特性(allocator traits)表明分配器应该传播(propagate),则函数永远不会抛出异常(无抛出保证)。
否则,它将导致未定义的行为。