opérateur== (unordered_map)
Teste si l'unordered_map à gauche de l'opérateur n'est pas égal à l'objet est différent de l'unordered_map à droite.
bool operator==(
const unordered_map <Key, Type, Hash, Pred, Allocator>& _Left,
const unordered_map <Key, Type, Hash, Pred, Allocator>& _Right
);
Paramètres
_Left
Objet de type unordered_map._Right
Objet de type unordered_map.
Valeur de retour
true si les unordered_maps sont égaux ; false s'ils sont différents.
Notes
La comparaison entre des objets unordered_map n'est pas affectée par l'ordre aléatoire avec lequel ils stockent leurs éléments. Deux unordered_maps sont égaux s'ils ont le même nombre d'éléments et les éléments dans un conteneur sont une permutation des éléments dans l'autre conteneur. Sinon, ils sont inégaux.
Exemple
// unordered_map_op_eq.cpp
// compile by using: cl.exe /EHsc /nologo /W4 /MTd
#include <unordered_map>
#include <iostream>
#include <ios>
int main( )
{
using namespace std;
unordered_map<int, int> um1, um2, um3;
for ( int i = 0 ; i < 3 ; ++i ) {
um1.insert( make_pair( i+1, i ) );
um1.insert( make_pair( i, i ) );
um2.insert( make_pair( i, i+1 ) );
um2.insert( make_pair( i, i ) );
um3.insert( make_pair( i, i ) );
um3.insert( make_pair( i+1, i ) );
}
cout << boolalpha;
cout << "um1 == um2: " << (um1 == um2) << endl;
cout << "um1 == um3: " << (um1 == um3) << endl;
cout << "um2 == um3: " << (um2 == um3) << endl;
}
Sortie :
um1 == um2: false
um1 == um3: true
um2 == um3: false
Configuration requise
En-tête : <unordered_map>
Espace de noms : std