hash_set::hash_set
[!POZNÁMKA]
Toto rozhraní API je zastaralé.Alternativou je unordered_set Class.
Konstrukce hash_set je prázdné nebo je kopírovat všechny nebo některé další část hash_set.
hash_set( );
explicit hash_set(
const Traits& _Comp
);
hash_set(
const Traits& _Comp,
const Allocator& _Al
);
hash_set(
const hash_set<Key, Traits, Allocator>& _Right
);
template<class InputIterator>
hash_set(
InputIterator _First,
InputIterator _Last
);
template<class InputIterator>
hash_set(
InputIterator _First,
InputIterator _Last,
const Traits& _Comp
);
template<class InputIterator>
hash_set(
InputIterator _First,
InputIterator _Last,
const Traits& _Comp,
const Allocator& _Al
);
hash_set(
hash_set&& _Right
);
Parametry
Parametr |
Description |
_Al |
Třída přidělování úložiště pro tento hash_set objekt, který se standardně Allocator. |
_Comp |
Porovnání funkce typu const Traits pro prvky v pořadí hash_set, které výchozí hash_compare. |
_Right |
hash_set z nichž vyrobeno hash_set musí být kopie. |
_First |
První prvek pozice v rozsahu prvků, které mají být zkopírovány. |
_Last |
Pozice první prvek mimo rozsah prvků, které mají být zkopírovány. |
Poznámky
Typ objektu přidělování, který spravuje úložiště paměti pro ukládání všechny konstruktory hash_set a později, může vrácený voláním hash_set::get_allocator.Parametr přidělování je často vynechán předzpracování makra použít náhradní alternativní allocators a deklarace třídy.
Všechny konstruktory inicializovat jejich hash_sets.
Uložit všechny konstruktory funkce objekt typu Traits , se používá k vytvoření objednávky mezi klíče hash_set a později, může vrácený voláním hash_set::key_comp.Další informace o Traits najdete hash_set Class téma.
Další tři konstruktory zadat prázdný počáteční hash_set, druhé určující typ porovnání funkce (_Comp) používané při stanovení pořadí prvků a třetí explicitně zadáním přidělujícího modulu zadejte (_Al) má být použita.Klíčové slovo explicit potlačí určité druhy automatické typ převodu.
Čtvrtý konstruktor určuje kopii hash_set_Right.
Zkopírujte poslední tři konstruktory [_First, _Last) z hash_set s rostoucí explicitness v určující typ porovnání funkce vlastnosti třídy a přidělování.
Poslední konstruktor přesune hash_set_Right.
Skutečné pořadí prvků hash_set kontejneru závisí na funkci hash funkce řazení a a aktuální velikost hash tabulky nelze předpovědět obecně, jako by sada kontejneru, kde byla určena samotné funkce řazení.
Příklad
// hash_set_hash_set.cpp
// compile with: /EHsc
#include <hash_set>
#include <iostream>
int main( )
{
using namespace std;
using namespace stdext;
hash_set <int>::iterator hs1_Iter, hs3_Iter, hs4_Iter,
hs5_Iter, hs6_Iter, hs7_Iter;
hash_set <int, hash_compare <int, greater<int> > >::iterator
hs2_Iter;
// Create an empty hash_set hs0 of key type integer
hash_set <int> hs0;
// Create an empty hash_set hs1 with the key comparison
// function of less than, then insert 4 elements
hash_set <int, hash_compare <int, less<int> > > hs1;
hs1.insert( 10 );
hs1.insert( 20 );
hs1.insert( 30 );
hs1.insert( 40 );
// Create an empty hash_set hs2 with the key comparison
// function of geater than, then insert 2 elements
hash_set <int, hash_compare <int, greater<int> > > hs2;
hs2.insert(10);
hs2.insert(20);
// Create a hash_set hs3 with the
// allocator of hash_set hs1
hash_set <int>::allocator_type hs1_Alloc;
hs1_Alloc = hs1.get_allocator( );
hash_set <int> hs3( hash_compare <int, less<int> >( ),
hs1_Alloc );
hs3.insert( 30 );
// Create a copy, hash_set hs4, of hash_set hs1
hash_set <int> hs4( hs1 );
// Create a hash_set hs5 by copying the range hs1[_First, _Last)
hash_set <int>::const_iterator hs1_bcIter, hs1_ecIter;
hs1_bcIter = hs1.begin( );
hs1_ecIter = hs1.begin( );
hs1_ecIter++;
hs1_ecIter++;
hash_set <int> hs5( hs1_bcIter, hs1_ecIter );
// Create a hash_set hs6 by copying the range hs4[_First, _Last)
// and with the allocator of hash_set hs2
hash_set <int>::allocator_type hs2_Alloc;
hs2_Alloc = hs2.get_allocator( );
hash_set <int> hs6( hs4.begin( ), ++hs4.begin( ),
less<int>( ), hs2_Alloc );
cout << "hs1 = ";
for ( hs1_Iter = hs1.begin( ); hs1_Iter != hs1.end( );
hs1_Iter++ )
cout << *hs1_Iter << " ";
cout << endl;
cout << "hs2 = " ;
for ( hs2_Iter = hs2.begin( ); hs2_Iter != hs2.end( );
hs2_Iter++ )
cout << *hs2_Iter << " ";
cout << endl;
cout << "hs3 = ";
for ( hs3_Iter = hs3.begin( ); hs3_Iter != hs3.end( );
hs3_Iter++ )
cout << *hs3_Iter << " ";
cout << endl;
cout << "hs4 = ";
for ( hs4_Iter = hs4.begin( ); hs4_Iter != hs4.end( );
hs4_Iter++ )
cout << *hs4_Iter << " ";
cout << endl;
cout << "hs5 = ";
for ( hs5_Iter = hs5.begin( ); hs5_Iter != hs5.end( );
hs5_Iter++ )
cout << *hs5_Iter << " ";
cout << endl;
cout << "hs6 = ";
for ( hs6_Iter = hs6.begin( ); hs6_Iter != hs6.end( );
hs6_Iter++ )
cout << *hs6_Iter << " ";
cout << endl;
// Create a copy, hash_set hs7, of hash_set hs1 by moving
hash_set <int, hash_compare <int, less<int> > >
hs7(move(hs1);
cout << "hs7 =";
for (hs7_Iter = hs7.begin(); hs7_Iter != hs7.end(); hs7_Iter++)
cout << " " << hs7_Iter -> second;
cout << endl;
}
Výsledek
hs1 = 40 10 20 30
hs2 = 10 20
hs3 = 30
hs4 = 40 10 20 30
hs5 = 40 10
hs6 = 40
hs7 = 40 10 20 30
Požadavky
Záhlaví: <hash_set>
Obor názvů: stdext