hash_map::hash_map (STL/CLR)
Erstellt ein container-Objekt.
hash_map();
explicit hash_map(key_compare^ pred);
hash_map(key_compare^ pred, hasher^ hashfn);
hash_map(hash_map<Key, Mapped>% right);
hash_map(hash_map<Key, Mapped>^ right);
template<typename InIter>
hash_maphash_map(InIter first, InIter last);
template<typename InIter>
hash_map(InIter first, InIter last,
key_compare^ pred);
template<typename InIter>
hash_map(InIter first, InIter last,
key_compare^ pred, hasher^ hashfn);
hash_map(System::Collections::Generic::IEnumerable<GValue>^ right);
hash_map(System::Collections::Generic::IEnumerable<GValue>^ right,
key_compare^ pred);
hash_map(System::Collections::Generic::IEnumerable<GValue>^ right,
key_compare^ pred, hasher^ hashfn);
Parameter
first
Anfang Einfügen des Bereichs.hashfn
Hashfunktion für die Zuordnung von Schlüsseln auf die Buckets.last
Ende Einfügen des Bereichs.pred
Reihenfolgenprädikat für die gesteuerte Sequenz.right
Objekt oder Bereich Einfüge-.
Hinweise
Der Konstruktor:
hash_map();
initialisiert die gesteuerte Sequenz ohne Elemente, mit dem Standardreihenfolgenprädikat key_compare() mit der Standardhashfunktion. Sie verwenden sie, um eine leere gesteuerten ursprünglichen Sequenz, mit dem Standardreihenfolgenprädikat und -Hashfunktion anzugeben.
Der Konstruktor:
explicit hash_map(key_compare^ pred);
initialisiert die gesteuerte Sequenz ohne Elemente, mit dem Reihenfolgenprädikat pred mit der Standardhashfunktion. Sie verwenden sie, um eine leere gesteuerten ursprünglichen Sequenz, mit dem angegebenen Reihenfolgenprädikat und der Standardhashfunktion anzugeben.
Der Konstruktor:
hash_map(key_compare^ pred, hasher^ hashfn);
initialisiert die gesteuerte Sequenz ohne Elemente, mit dem Reihenfolgenprädikat pred mit der Hashfunktion hashfn. Sie verwenden sie, um eine leere gesteuerten ursprünglichen Sequenz, mit dem angegebenen Reihenfolgenprädikat und -Hashfunktion anzugeben.
Der Konstruktor:
hash_map(hash_map<Key, Mapped>% right);
initialisiert die gesteuerte Sequenz mit der Sequenz [right.hash_map::begin (STL/CLR)(), right.hash_map::end (STL/CLR)()), mit dem Standardreihenfolgenprädikat und mit der Standardhashfunktion. Sie verwenden sie, um einer gesteuerten ursprünglichen Sequenz angeben, die eine Kopie dieser Folge ist, die vom hash_map Objekt right, mit dem Standardreihenfolgenprädikat und -Hashfunktion gesteuert wird.
Der Konstruktor:
hash_map(hash_map<Key, Mapped>^ right);
initialisiert die gesteuerte Sequenz mit der Sequenz [right->hash_map::begin (STL/CLR)(), right->hash_map::end (STL/CLR)()), mit dem Standardreihenfolgenprädikat und mit der Standardhashfunktion. Sie verwenden sie, um einer gesteuerten ursprünglichen Sequenz angeben, die eine Kopie dieser Folge ist, die vom hash_map Objekt right, mit dem Standardreihenfolgenprädikat und -Hashfunktion gesteuert wird.
Der Konstruktor:
template<typename InIter>
hash_map(InIter first, InIter last);
initialisiert die gesteuerte Sequenz mit der Sequenz [first, last), mit dem Standardreihenfolgenprädikat und mit der Standardhashfunktion. Sie verwenden sie, um die gesteuerte Sequenz eine Kopie einer anderen Sequenz, mit dem Standardreihenfolgenprädikat und -Hashfunktion zu erstellen.
Der Konstruktor:
template<typename InIter>
hash_map(InIter first, InIter last,
key_compare^ pred);
initialisiert die gesteuerte Sequenz mit der Sequenz [first, last), mit dem Reihenfolgenprädikat pred mit der Standardhashfunktion. Sie verwenden sie, um die gesteuerte Sequenz eine Kopie einer anderen Sequenz, mit dem angegebenen Reihenfolgenprädikat und der Standardhashfunktion zu erstellen.
Der Konstruktor:
template<typename InIter>
hash_map(InIter first, InIter last,
key_compare^ pred, hasher^ hashfn);
initialisiert die gesteuerte Sequenz mit der Sequenz [first, last), mit dem Reihenfolgenprädikat pred mit der Hashfunktion hashfn. Sie verwenden sie, um die gesteuerte Sequenz eine Kopie einer anderen Sequenz, mit dem angegebenen Reihenfolgenprädikat und -Hashfunktion zu erstellen.
Der Konstruktor:
hash_map(System::Collections::Generic::IEnumerable<Key>^ right);
initialisiert die gesteuerte Sequenz mit der Folge, die der Enumerator right festgelegt wird, mit dem Standardreihenfolgenprädikat und mit der Standardhashfunktion. Sie verwenden sie, um die gesteuerte Sequenz eine Kopie einer anderen Sequenz erstellen, die von ein Enumerator, mit dem Standardreihenfolgenprädikat und -Hashfunktion beschrieben wird.
Der Konstruktor:
hash_map(System::Collections::Generic::IEnumerable<Key>^ right,
key_compare^ pred);
initialisiert die gesteuerte Sequenz mit der Folge, die der Enumerator right festgelegt wird, mit dem Reihenfolgenprädikat pred mit der Standardhashfunktion. Sie verwenden sie, um die gesteuerte Sequenz eine Kopie einer anderen Sequenz erstellen, die von ein Enumerator, mit der angegebenen Reihenfolgenprädikat- und -Standardhashfunktion beschrieben wird.
Der Konstruktor:
hash_map(System::Collections::Generic::IEnumerable<Key>^ right,
key_compare^ pred, hasher^ hashfn);
initialisiert die gesteuerte Sequenz mit der Folge, die der Enumerator right festgelegt wird, mit dem Reihenfolgenprädikat pred mit der Hashfunktion hashfn. Sie verwenden sie, um die gesteuerte Sequenz eine Kopie einer anderen Sequenz erstellen, die von ein Enumerator, mit dem angegebenen Reihenfolgenprädikat und -Hashfunktion beschrieben wird.
Beispiel
// cliext_hash_map_construct.cpp
// compile with: /clr
#include <cliext/hash_map>
int myfun(wchar_t key)
{ // hash a key
return (key ^ 0xdeadbeef);
}
typedef cliext::hash_map<wchar_t, int> Myhash_map;
int main()
{
// construct an empty container
Myhash_map c1;
System::Console::WriteLine("size() = {0}", c1.size());
c1.insert(Myhash_map::make_value(L'a', 1));
c1.insert(Myhash_map::make_value(L'b', 2));
c1.insert(Myhash_map::make_value(L'c', 3));
for each (Myhash_map::value_type elem in c1)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
// construct with an ordering rule
Myhash_map c2 = cliext::greater_equal<wchar_t>();
System::Console::WriteLine("size() = {0}", c2.size());
c2.insert(c1.begin(), c1.end());
for each (Myhash_map::value_type elem in c2)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
// construct with an ordering rule and hash function
Myhash_map c2h(cliext::greater_equal<wchar_t>(),
gcnew Myhash_map::hasher(&myfun));
System::Console::WriteLine("size() = {0}", c2h.size());
c2h.insert(c1.begin(), c1.end());
for each (Myhash_map::value_type elem in c2h)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine();
// construct with an iterator range
Myhash_map c3(c1.begin(), c1.end());
for each (Myhash_map::value_type elem in c3)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
// construct with an iterator range and an ordering rule
Myhash_map c4(c1.begin(), c1.end(),
cliext::greater_equal<wchar_t>());
for each (Myhash_map::value_type elem in c4)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
// construct with an iterator range and an ordering rule and hash function
Myhash_map c4h(c1.begin(), c1.end(),
cliext::greater_equal<wchar_t>(),
gcnew Myhash_map::hasher(&myfun));
for each (Myhash_map::value_type elem in c4h)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine();
// construct with an enumeration
Myhash_map c5( // NOTE: cast is not needed
(System::Collections::Generic::IEnumerable<
Myhash_map::value_type>^)%c3);
for each (Myhash_map::value_type elem in c5)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
// construct with an enumeration and an ordering rule
Myhash_map c6( // NOTE: cast is not needed
(System::Collections::Generic::IEnumerable<
Myhash_map::value_type>^)%c3,
cliext::greater_equal<wchar_t>());
for each (Myhash_map::value_type elem in c6)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
// construct with an enumeration and an ordering rule and hash function
Myhash_map c6h( // NOTE: cast is not needed
(System::Collections::Generic::IEnumerable<
Myhash_map::value_type>^)%c3,
cliext::greater_equal<wchar_t>(),
gcnew Myhash_map::hasher(&myfun));
for each (Myhash_map::value_type elem in c6h)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
System::Console::WriteLine();
// construct by copying another container
Myhash_map c7(c4);
for each (Myhash_map::value_type elem in c7)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
// construct by copying a container handle
Myhash_map c8(%c3);
for each (Myhash_map::value_type elem in c8)
System::Console::Write(" [{0} {1}]", elem->first, elem->second);
System::Console::WriteLine();
return (0);
}
Anforderungen
Header: <cliext/hash_map>
Namespace: cliext