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


複雜度

常量。

迭代器有效性

所有迭代器、指標和引用都保持有效,但現在它們指向其他容器中的元素,並在其中進行迭代。

另見