hash_multiset::hash_multiset (STL/CLR)
Construit un objet.
hash_multiset();
explicit hash_multiset(key_compare^ pred);
hash_multiset(key_compare^ pred, hasher^ hashfn);
hash_multiset(hash_multiset<Key>% right);
hash_multiset(hash_multiset<Key>^ right);
template<typename InIter>
hash_multiset(InIter first, InIter last);
template<typename InIter>
hash_multiset(InIter first, InIter last,
key_compare^ pred);
template<typename InIter>
hash_multiset(InIter first, InIter last,
key_compare^ pred, hasher^ hashfn);
hash_multiset(System::Collections::Generic::IEnumerable<GValue>^ right);
hash_multiset(System::Collections::Generic::IEnumerable<GValue>^ right,
key_compare^ pred);
hash_multiset(System::Collections::Generic::IEnumerable<GValue>^ right,
key_compare^ pred, hasher^ hashfn);
Paramètres
tout d'abord
Début de la plage à insérer.hashfn
Fonction de hachage pour mapper des clés dans des compartiments restant.last
Fin de la plage à insérer.pred
Classer l'attribut pour la séquence contrôlée.right
Objet ou plage à ajouter.
Notes
Le constructeur :
hash_multiset();
initialise la séquence contrôlée sans éléments, avec l'attribut classant par défaut key_compare(), et avec la fonction de hachage par défaut.Vous l'utilisez pour spécifier une séquence contrôlée par initiale vide, avec l'attribut et la fonction de hachage classants par défaut.
Le constructeur :
explicit hash_multiset(key_compare^ pred);
initialise la séquence contrôlée sans éléments, avec l'attribut classement pred, et avec la fonction de hachage par défaut.Vous l'utilisez pour spécifier une séquence contrôlée par initiale vide, avec l'attribut classement spécifié et la fonction de hachage par défaut.
Le constructeur :
hash_multiset(key_compare^ pred, hasher^ hashfn);
initialise la séquence contrôlée sans éléments, avec l'attribut classement pred, et avec la fonction de hachage hashfn.Vous l'utilisez pour spécifier une séquence contrôlée par initiale vide, avec l'attribut et la fonction de hachage classants spécifiés.
Le constructeur :
hash_multiset(hash_multiset<Key>% right);
initialise la séquence contrôlée avec la séquence [right.hash_multiset::begin (STL/CLR)(),right.hash_multiset::end (STL/CLR)()), avec l'attribut classant par défaut, et avec la fonction de hachage par défaut.Vous l'utilisez pour spécifier une séquence contrôlée par défaut qui est une copie de la séquence contrôlée par l'objet rightde hash_multiset, avec l'attribut et la fonction de hachage classants par défaut.
Le constructeur :
hash_multiset(hash_multiset<Key>^ right);
initialise la séquence contrôlée avec la séquence [right->hash_multiset::begin (STL/CLR)(),right->hash_multiset::end (STL/CLR)()), avec l'attribut classant par défaut, et avec la fonction de hachage par défaut.Vous l'utilisez pour spécifier une séquence contrôlée par défaut qui est une copie de la séquence contrôlée par l'objet rightde hash_multiset, avec l'attribut et la fonction de hachage classants par défaut.
Le constructeur :
template<typename InIter>
hash_multiset(InIter first, InIter last);
initialise la séquence contrôlée avec la séquence [first,last), avec l'attribut classant par défaut, et avec la fonction de hachage par défaut.Vous l'utilisez pour tirer à la séquence est contrôlée par une copie d'une autre séquence, avec l'attribut et la fonction de hachage classants par défaut.
Le constructeur :
template<typename InIter>
hash_multiset(InIter first, InIter last,
key_compare^ pred);
initialise la séquence contrôlée avec la séquence [first,last), avec l'attribut classement pred, et avec la fonction de hachage par défaut.Vous l'utilisez pour tirer à la séquence est contrôlée par une copie d'une autre séquence, avec l'attribut classement spécifié et la fonction de hachage par défaut.
Le constructeur :
template<typename InIter>
hash_multiset(InIter first, InIter last,
key_compare^ pred, hasher^ hashfn);
initialise la séquence contrôlée avec la séquence [first,last), avec l'attribut classement pred, et avec la fonction de hachage hashfn.Vous l'utilisez pour tirer à la séquence est contrôlée par une copie d'une autre séquence, avec l'attribut et la fonction de hachage classants spécifiés.
Le constructeur :
hash_multiset(System::Collections::Generic::IEnumerable<Key>^ right);
initialise la séquence contrôlée avec la séquence indiquée par l'énumérateur right, avec l'attribut classant par défaut, et avec la fonction de hachage par défaut.Vous l'utilisez pour tirer à la séquence est contrôlée par une copie d'une autre séquence décrite par un énumérateur, avec l'attribut et la fonction de hachage classants par défaut.
Le constructeur :
hash_multiset(System::Collections::Generic::IEnumerable<Key>^ right,
key_compare^ pred);
initialise la séquence contrôlée avec la séquence indiquée par l'énumérateur right, avec l'attribut classement pred, et avec la fonction de hachage par défaut.Vous l'utilisez pour tirer à la séquence est contrôlée par une copie d'une autre séquence décrite par un énumérateur, avec l'attribut et la fonction de hachage classants spécifiés par défaut.
Le constructeur :
hash_multiset(System::Collections::Generic::IEnumerable<Key>^ right,
key_compare^ pred, hasher^ hashfn);
initialise la séquence contrôlée avec la séquence indiquée par l'énumérateur right, avec l'attribut classement pred, et avec la fonction de hachage hashfn.Vous l'utilisez pour tirer à la séquence est contrôlée par une copie d'une autre séquence décrite par un énumérateur, avec l'attribut et la fonction de hachage classants spécifiés.
Exemple
// cliext_hash_multiset_construct.cpp
// compile with: /clr
#include <cliext/hash_set>
int myfun(wchar_t key)
{ // hash a key
return (key ^ 0xdeadbeef);
}
typedef cliext::hash_multiset<wchar_t> Myhash_multiset;
int main()
{
// construct an empty container
Myhash_multiset c1;
System::Console::WriteLine("size() = {0}", c1.size());
c1.insert(L'a');
c1.insert(L'b');
c1.insert(L'c');
for each (wchar_t elem in c1)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
// construct with an ordering rule
Myhash_multiset c2 = cliext::greater_equal<wchar_t>();
System::Console::WriteLine("size() = {0}", c2.size());
c2.insert(c1.begin(), c1.end());
for each (wchar_t elem in c2)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
// construct with an ordering rule and hash function
Myhash_multiset c2h(cliext::greater_equal<wchar_t>(),
gcnew Myhash_multiset::hasher(&myfun));
System::Console::WriteLine("size() = {0}", c2h.size());
c2h.insert(c1.begin(), c1.end());
for each (wchar_t elem in c2h)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
System::Console::WriteLine();
// construct with an iterator range
Myhash_multiset c3(c1.begin(), c1.end());
for each (wchar_t elem in c3)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
// construct with an iterator range and an ordering rule
Myhash_multiset c4(c1.begin(), c1.end(),
cliext::greater_equal<wchar_t>());
for each (wchar_t elem in c4)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
// construct with an iterator range and an ordering rule and hash function
Myhash_multiset c4h(c1.begin(), c1.end(),
cliext::greater_equal<wchar_t>(),
gcnew Myhash_multiset::hasher(&myfun));
for each (wchar_t elem in c4h)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
System::Console::WriteLine();
// construct with an enumeration
Myhash_multiset c5( // NOTE: cast is not needed
(System::Collections::Generic::IEnumerable<wchar_t>^)%c3);
for each (wchar_t elem in c5)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
// construct with an enumeration and an ordering rule
Myhash_multiset c6( // NOTE: cast is not needed
(System::Collections::Generic::IEnumerable<wchar_t>^)%c3,
cliext::greater_equal<wchar_t>());
for each (wchar_t elem in c6)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
// construct with an enumeration and an ordering rule and hash function
Myhash_multiset c6h( // NOTE: cast is not needed
(System::Collections::Generic::IEnumerable<wchar_t>^)%c3,
cliext::greater_equal<wchar_t>(),
gcnew Myhash_multiset::hasher(&myfun));
for each (wchar_t elem in c6h)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
System::Console::WriteLine();
// construct from a generic container
Myhash_multiset c7(c4);
for each (wchar_t elem in c7)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
// construct by copying another container
Myhash_multiset c8(%c3);
for each (wchar_t elem in c8)
System::Console::Write(" {0}", elem);
System::Console::WriteLine();
return (0);
}
Configuration requise
en-tête :<cliext/hash_set>
Cliext del'espace de noms :