Sdílet prostřednictvím


unordered_map Class

Popisuje šablony třídy objektu, který řídí různé délky pořadí prvků typu std::pair<const Key, Ty>.Posloupnost je slabě seřazený podle funkce hash oddíly sekvence do uspořádanou sadu dílčích sekvencí nazývají bloky.V rámci každého bloku porovnání funkce určuje, zda všechny dvojice prvků má, odpovídající pořadí.Každý prvek ukládá dva objekty, klíč řazení a hodnotu.Pořadí je reprezentován způsobem, který umožňuje vyhledávání, vkládání a odstraňování libovolný prvek s počtem operací, které mohou být nezávisle na počtu prvků v posloupnosti (konstantní čas), alespoň pokud všechny bloky jsou přibližně stejné délky.V nejhorším případě když jsou všechny prvky v jednom bloku počet operací je úměrná počtu prvků v posloupnosti (lineární čas).Kromě vkládání prvek přestanou platit žádné u iterátorů a odebrání prvku zruší platnost pouze ty u iterátorů které na odebraný prvek.

template<class Key,
    class Ty,
    class Hash = std::hash<Key>,
    class Pred = std::equal_to<Key>,
    class Alloc = std::allocator<std::pair<const Key, Ty> > >
    class unordered_map;

Parametry

Parametr

Description

Key

Typ klíče.

Ty

Mapované typu.

Hash

Typ objektu funkce hash.

Pred

Typ objektu rovnosti porovnání funkce.

Alloc

Třída přidělování.

Členy

Definice typu

Description

unordered_map::allocator_type

Typ přidělování pro správu paměti.

unordered_map::const_iterator

Typ konstantní iterační řízené posloupnosti.

unordered_map::const_local_iterator

Typ konstantní plechovka iterační řízené posloupnosti.

unordered_map::const_pointer

Typ konstantní ukazatel na prvek.

unordered_map::const_reference

Typ konstantní odkaz na element.

unordered_map::difference_type

Typ podepsané vzdálenost mezi dvěma prvky.

unordered_map::hasher

Typ funkce hash.

unordered_map::iterator

Typ iterace řízené posloupnosti.

unordered_map::key_equal

Typ funkce porovnání.

unordered_map::key_type

Typ řazení klíč.

unordered_map::local_iterator

Typ bloku iterační řízené posloupnosti.

unordered_map::mapped_type

Typ mapované hodnoty přiřazené každému klíči.

unordered_map::pointer

Typ ukazatel na prvek.

unordered_map::reference

Typ odkazu na prvek.

unordered_map::size_type

Typ bez znaménka vzdálenost mezi dvěma prvky.

unordered_map::value_type

Typ prvku.

Členská funkce

Description

hash_map::begin

Vyhledá prvek se zadaným klíčem.

unordered_map::begin

Označí začátek řízené sekvence.

unordered_map::bucket

Získá číslo bloku pro hodnotu klíče.

unordered_map::bucket_count

Počet bloků získá.

unordered_map::bucket_size

Velikost bloku získá.

hash_map::begin

Označí začátek řízené sekvence.

hash_map::begin

Označí konci řízené sekvence.

unordered_map::clear

Odebere všechny prvky.

unordered_map::count

Najde zadaný klíč odpovídající počet.

hash_map::begin

Přidá prvek vyrobeno na místě.

hash_map::begin

Přidá prvek vyrobeno na místě s nápovědy.

unordered_map::empty

Zkoušky, zda jsou žádné prvky prezentovat.

unordered_map::end

Označí konci řízené sekvence.

unordered_map::equal_range

Najde rozsah, který odpovídá zadaným klíčem.

unordered_map::erase

Odebere prvky v určených polohách.

unordered_map::find

Najde zadaný klíč odpovídající prvek.

unordered_map::get_allocator

Načte uložené přidělování objektu.

unordered_map::hash_function

Načte uložené hodnoty hash funkce objektu.

unordered_map::insert

Přidá prvky.

unordered_map::key_eq

Načte uložené porovnání funkce objektu.

unordered_map::load_factor

Spočítá průměrnou prvky za plechovka.

unordered_map::max_bucket_count

Získává maximální počet bloků.

unordered_map::max_load_factor

Získá nebo nastaví maximální prvky za plechovka barvy.

unordered_map::max_size

Maximální velikost kontrolované sekvence získá.

unordered_map::rehash

Znovu vytvoří tabulky hash.

unordered_map::size

Vrátí počet prvků.

unordered_map::swap

Zamění obsah dva kontejnery.

unordered_map::unordered_map

Konstrukce objektu kontejneru.

Operátor

Description

unordered_map::operator[]

Vyhledá nebo vloží prvek se zadaným klíčem.

hash_map::begin

Zkopíruje tabulky hash.

Poznámky

Objekt objednávky pořadí ovládacích prvků voláním dvě uložené objekty objekt porovnání funkce typu unordered_map::key_equal a objekt hash funkce typu unordered_map::hasher.Přístup k první uložené objekt voláním funkce členské unordered_map::key_eq(); přístup druhý objekt uložené voláním funkce členské unordered_map::hash_function().Konkrétně pro všechny hodnoty X a Y typu Key, volání key_eq()(X, Y) vrátí hodnotu true pouze v případě dvou argument hodnoty odpovídající pořadí; volání hash_function()(keyval) vede k rozdělení hodnot typu size_t.Na rozdíl od šablony třídy unordered_multimap Class, objekt šablony třídy unordered_map zajišťuje, že key_eq()(X, Y) je vždy false u dvou prvků řízené sekvence.(Klíče jsou jedinečné).

Objekt také ukládá maximální zatížení faktor, které specifikuje že maximální požadovaný průměrný počet prvků na bloku.Pokud způsobí vložení prvku unordered_map::load_factor() kontejner překročit maximální zatížení faktor zvyšuje počet bloků a znovu vytvoří tabulky hash podle potřeby.

Skutečné pořadí prvků v řízené posloupnosti závisí na funkci hash funkce porovnání, pořadí vložení, faktor maximálního zatížení a aktuální počet bloků.Obecně nelze předpovědět pořadí prvků v řízené sekvenci.Je vždy možno, však, že všechny dílčí prvky, které mají ekvivalentní objednávání sousedí řízené posloupnosti.

Objekt přidělení a uvolnění úložiště pro sekvence řídí přidělování uložené objektem typu unordered_map::allocator_type.Takový objekt přidělování musí mít stejné externí rozhraní jako objekt šablony třídy allocator.Poznámka: objekt uložené Alokátor se nezkopíruje při přiřazení objektu kontejneru.

Požadavky

Záhlaví: <unordered_map>

Obor názvů: std

Viz také

Referenční dokumentace

<unordered_map>

unordered_map Class

Další zdroje

<unordered_map> Členové