std::array<T,N>:: swap
From cppreference.net
|
void
swap
(
array
&
other
)
noexcept
(
/* see below */
)
;
|
(自 C++11 起)
(自 C++20 起为 constexpr) |
|
交换容器内容与 other 的内容。不会导致迭代器和引用与另一容器关联。
目录 |
参数
| 其他 | - | 用于交换内容的容器 |
返回值
(无)
异常
|
noexcept
规范:
noexcept
(
noexcept
(
swap
(
std::
declval
<
T
&
>
(
)
,
std::
declval
<
T
&
>
(
)
)
)
)
在上述表达式中,标识符
|
(C++17 前) |
|
noexcept
规范:
noexcept
(
std::
is_nothrow_swappable_v
<
T
>
)
|
(C++17 起) |
noexcept
规范:
noexcept
复杂度
与容器大小呈线性关系。
示例
运行此代码
#include <array> #include <iostream> template<class Os, class V> Os& operator<<(Os& os, const V& v) { os << '{'; for (auto i : v) os << ' ' << i; return os << " } "; } int main() { std::array<int, 3> a1{1, 2, 3}, a2{4, 5, 6}; auto it1 = a1.begin(); auto it2 = a2.begin(); int& ref1 = a1[1]; int& ref2 = a2[1]; std::cout << a1 << a2 << *it1 << ' ' << *it2 << ' ' << ref1 << ' ' << ref2 << '\n'; a1.swap(a2); std::cout << a1 << a2 << *it1 << ' ' << *it2 << ' ' << ref1 << ' ' << ref2 << '\n'; // 注意交换后迭代器和引用仍与其原始数组保持关联 // 例如 `it1` 仍指向元素 a1[0],`ref1` 仍引用 a1[1] }
输出:
{ 1 2 3 } { 4 5 6 } 1 4 2 5
{ 4 5 6 } { 1 2 3 } 4 1 5 2
缺陷报告
以下行为变更缺陷报告被追溯应用于先前发布的C++标准。
| 缺陷报告 | 适用范围 | 发布时的行为 | 正确行为 |
|---|---|---|---|
| LWG 2456 | C++11 |
noexcept
规范格式错误
|
已修复可用 |
参见
|
(C++11)
|
特化
std::swap
算法
(函数模板) |