public member function
<unordered_map>

std::unordered_multimap::swap

void swap ( unordered_multimap& umm );
交换内容
将本容器的内容与 umm 的内容交换,umm 是一个包含相同类型元素的 unordered_multimap 对象。大小可能不同。

调用此成员函数后,本容器中的元素将是调用前 umm 中的元素,而 umm 中的元素将是this中的元素。容器内部保持的其他对象(例如其hasherkey_equal对象)也会被交换。

此函数在不实际复制或移动单个元素的情况下,交换容器之间的内部数据指针,从而允许以恒定的时间执行,而不考虑大小。

请注意,存在一个同名的全局算法函数 swap。此全局函数被重载为 unordered_multimap 参数,以具有与此成员函数相同的行为和复杂度。

参数

umm
另一个与本对象类型相同的 unordered_multimap 容器对象。

返回值



示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
// unordered_multimap::swap
#include <iostream>
#include <string>
#include <unordered_map>

int main ()
{
  std::unordered_multimap<std::string,std::string>
     a = {{"orange","FL"},{"apple","NY"},{"apple","WA"}},
     b  = {{"strawberry","LA"},{"strawberry","NC"},{"pear","OR"}};

  a.swap(b);

  std::cout << "a: ";
  for (auto& x: a) std::cout << " " << x.first << ":" << x.second;
  std::cout << std::endl;

  std::cout << "b: ";
  for (auto& x: b) std::cout << " " << x.first << ":" << x.second;
  std::cout << std::endl;

  return 0;
}

可能的输出
a:  pear:OR strawberry:LA strawberry:NC
b:  orange:FL apple:NY apple:WA


复杂度

常量。

迭代器有效性

所有迭代器、指针和引用都保持有效,但现在它们指向其他容器中的元素,并在其中进行迭代。

另见