Compartir a través de


hash_multiset::key_comp

[!NOTA]

Esta API está obsoleta.La alternativa es unordered_multiset Class.

Recupera una copia del objeto de comparación utilizado a claves ordenadas en un hash_multiset.

key_compare key_comp( ) const;

Valor devuelto

Devuelve el parámetro Traitsde la plantilla de hash_multiset, que contiene los objetos de función que se utilizan al hash y ordenar los elementos del contenedor.

Para obtener más información sobre Traits vea el tema hash_multiset Class .

Comentarios

El objeto almacenado define una función miembro:

bool operator(const Key& _xVal, const Key& _yVal);

qué devuelve true si _xVal precede y no es igual a _yVal en el criterio de ordenación.

Observe que key_compare y value_compare son sinónimos para el parámetro Traitsde la plantilla.Proporcionan ambos tipos para el hash_multiset y las clases de hash_multiset, donde son idénticos, para la compatibilidad con las clases de hash_map y de hash_multimap, donde distintos.

En Visual C++ .NET 2003, los miembros de los archivos de encabezado <hash_map> y <hash_set> ya no están en el espacio de nombres std, pero se han movido bastante al espacio de nombres stdext.Vea El espacio de nombres stdext para obtener más información.

Ejemplo

// hash_multiset_key_comp.cpp
// compile with: /EHsc
#include <hash_set>
#include <iostream>

int main( )
{
   using namespace std;
   using namespace stdext;
   
   hash_multiset <int, hash_compare < int, less<int> > >hms1;
   hash_multiset<int, hash_compare < int, less<int> > >::key_compare kc1
          = hms1.key_comp( ) ;
   bool result1 = kc1( 2, 3 ) ;
   if( result1 == true )
   {
      cout << "kc1( 2,3 ) returns value of true, "
           << "where kc1 is the function object of hms1."
           << endl;
   }
   else
   {
      cout << "kc1( 2,3 ) returns value of false "
           << "where kc1 is the function object of hms1."
        << endl;
   }

   hash_multiset <int, hash_compare < int, greater<int> > > hms2;
   hash_multiset<int, hash_compare < int, greater<int> > >::key_compare
         kc2 = hms2.key_comp( ) ;
   bool result2 = kc2( 2, 3 ) ;
   if( result2 == true )
   {
      cout << "kc2( 2,3 ) returns value of true, "
           << "where kc2 is the function object of hms2."
           << endl;
   }
   else
   {
      cout << "kc2( 2,3 ) returns value of false, "
           << "where kc2 is the function object of hms2."
           << endl;
   }
}

Output

kc1( 2,3 ) returns value of true, where kc1 is the function object of hms1.
kc2( 2,3 ) returns value of false, where kc2 is the function object of hms2.

Requisitos

Encabezado: <hash_set>

Stdext deEspacio de nombres:

Vea también

Referencia

hash_multiset Class

Biblioteca de plantillas estándar