次の方法で共有


swap 関数 (unordered_multimap)

2 つのコンテナーのコンテンツを交換します。

template<class Key, class Ty, class Hash, class Pred, class Alloc>
    void swap(
        unordered_multimap <Key, Ty, Hash, Pred, Alloc>& left,
        unordered_multimap <Key, Ty, Hash, Pred, Alloc>& right);

パラメーター

  • Key
    キーの型。

  • Ty
    マップされた型。

  • Hash
    ハッシュ関数のオブジェクト型。

  • Pred
    等価比較関数のオブジェクト型。

  • Alloc
    アロケーター クラス。

  • left
    交換する 1 つ目のコンテナー。

  • right
    交換する 2 つ目のコンテナー。

解説

このテンプレート関数は、left.unordered_multimap::swap(right) を実行します。

使用例

 

// std_tr1__unordered_map__u_mm_swap.cpp 
// compile with: /EHsc 
#include <unordered_map> 
#include <iostream> 
 
typedef std::unordered_multimap<char, int> Mymap; 
int main() 
    { 
    Mymap c1; 
 
    c1.insert(Mymap::value_type('a', 1)); 
    c1.insert(Mymap::value_type('b', 2)); 
    c1.insert(Mymap::value_type('c', 3)); 
 
// display contents " [c 3] [b 2] [a 1]" 
    for (Mymap::const_iterator it = c1.begin(); 
        it != c1.end(); ++it) 
        std::cout << " [" << it->first << ", " << it->second << "]"; 
    std::cout << std::endl; 
 
    Mymap c2; 
 
    c2.insert(Mymap::value_type('d', 4)); 
    c2.insert(Mymap::value_type('e', 5)); 
    c2.insert(Mymap::value_type('f', 6)); 
 
    c1.swap(c2); 
 
// display contents " [f 6] [e 5] [d 4]" 
    for (Mymap::const_iterator it = c1.begin(); 
        it != c1.end(); ++it) 
        std::cout << " [" << it->first << ", " << it->second << "]"; 
    std::cout << std::endl; 
 
    swap(c1, c2); 
 
// display contents " [c 3] [b 2] [a 1]" 
    for (Mymap::const_iterator it = c1.begin(); 
        it != c1.end(); ++it) 
        std::cout << " [" << it->first << ", " << it->second << "]"; 
    std::cout << std::endl; 
 
    return (0); 
    } 
 
  

必要条件

ヘッダー: <unordered_map>

名前空間: std

参照

関連項目

<unordered_map>

unordered_multimap::swap

その他の技術情報

<unordered_map> メンバー