hash_multiset (STL/CLR)
Popisuje šablony třídy objektu, který řídí různé délky posloupnost prvků, která má obousměrný přístup.Použití kontejneru hash_multiset spravovat pořadí prvků jako tabulky hash každé položky tabulky obousměrným ukládání propojený seznam uzlů a každý uzel ukládání jeden prvek.Hodnota každého prvku slouží jako klíč pro pořadí řazení.
V popisu níže GValue je stejný jako GKey, který je stejný jako Key , není tento typ odkazu, v takovém případě je Key^.
template<typename Key>
ref class hash_multiset
: public
System::ICloneable,
System::Collections::IEnumerable,
System::Collections::ICollection,
System::Collections::Generic::IEnumerable<GValue>,
System::Collections::Generic::ICollection<GValue>,
System::Collections::Generic::IList<GValue>,
Microsoft::VisualC::StlClr::IHash<Gkey, GValue>
{ ..... };
Parametry
- Klíč
Typ klíče součásti prvku řízené sekvence.
Členy
Definice typu |
Description |
---|---|
Typ konstantní iterační řízené posloupnosti. |
|
Typ konstantní odkaz na element. |
|
Typ konstantní zpětného iterační řízené posloupnosti. |
|
Typ (případně podepsaný) vzdálenost mezi dvěma prvky. |
|
Typ kontejneru obecné rozhraní. |
|
Typ iterace obecné rozhraní pro kontejner. |
|
Typ zpětného iterační obecné rozhraní pro kontejner. |
|
Typ prvku obecné rozhraní kontejneru. |
|
Hash delegát pro klíč. |
|
Typ iterace řízené posloupnosti. |
|
Objednávání delegát dva klíče. |
|
Typ řazení klíč. |
|
Typ odkazu na prvek. |
|
Typ zpětného iterační řízené posloupnosti. |
|
Typ (kladné) vzdálenost mezi dvěma prvky. |
|
Objednávání delegát dvě hodnoty prvku. |
|
Typ prvku. |
Členská funkce |
Description |
---|---|
Označí začátek řízené sekvence. |
|
Vrátí počet bloků. |
|
Odebere všechny prvky. |
|
Zadaný klíč odpovídající počítá. |
|
Zkoušky, zda jsou žádné prvky prezentovat. |
|
Označí konec řízené sekvence. |
|
Najde rozsah, který odpovídá zadaným klíčem. |
|
Odebere prvky v určených polohách. |
|
Najde zadaný klíč odpovídající prvek. |
|
Zkopíruje hash delegát pro klíč. |
|
Konstrukce objektu kontejneru. |
|
Přidá prvky. |
|
Zkopíruje objednávání delegáta pro dva klíče. |
|
Spočítá průměrnou prvky za plechovka. |
|
Vyhledá začátek rozsahu, který odpovídá zadaným klíčem. |
|
Vytvoří objekt hodnoty. |
|
Získá nebo nastaví maximální prvky za plechovka barvy. |
|
Označí začátek řízené obrácené pořadí. |
|
Znovu vytvoří tabulky hash. |
|
Označí konec obrácené pořadí řízené. |
|
Vrátí počet prvků. |
|
Zamění obsah dva kontejnery. |
|
Řízené sekvence se zkopíruje do nového pole. |
|
Vyhledá konec rozsahu, který odpovídá zadaným klíčem. |
|
Zkopíruje objednávání delegáta pro dvě hodnoty prvku. |
Operátor |
Description |
---|---|
Nahradí řízené sekvence. |
Rozhraní
Rozhraní |
Description |
---|---|
Duplikujte objekt. |
|
Úsek mezi prvky. |
|
Zachovat skupiny prvků. |
|
Pořadové prostřednictvím typové prvky. |
|
Zachovat skupiny zadané prvků. |
|
IHash < klíč, hodnota > |
Udržují generic kontejneru. |
Poznámky
Objekt přiděluje a uvolní úložiště pro sekvence, které ovládá jako jednotlivé uzly v propojeném seznamu obousměrné.Urychlit přístup také různé délky pole ukazatelů do seznamu (tabulka hash) efektivní správě celý seznam jako posloupnost podseznamy, udržuje nebo objektu buckets.Prvky se vloží do bloku, který udržuje uspořádaný změnou propojení mezi uzly nikdy zkopírováním obsahu z jednoho uzlu do druhého.To znamená, můžete vložit a odebrat prvky volně bez narušení zbývající prvky.
Objekt objednávky každého bloku ovládací prvky voláním uložené delegát objekt typu hash_set::key_compare (STL/CLR).Můžete určit objekt uložených delegátem při konstrukci hash_set; Pokud nezadáte žádný objekt delegáta, výchozí hodnota je srovnání operator<=(key_type, key_type).
Přístup k objektu uložených delegátem voláním funkce členské hash_set::key_comp (STL/CLR)().Takový objekt delegát musí definovat řazení rovnocenné mezi klíče typu hash_set::key_type (STL/CLR).To znamená pro všechny dva klíče X a Y:
key_comp()(X, Y)Vrátí výsledek stejný Boolean při každém volání.
Pokud key_comp()(X, Y) && key_comp()(Y, X) je PRAVDA, pak X a Y jsou označeny mít rovnocenné objednávání.
Objednávání pravidla, která se chová jako operator<=(key_type, key_type), operator>=(key_type, key_type) nebo operator==(key_type, key_type) definuje pořadí eqivalent.
Všimněte si, že kontejner zajišťuje pouze prvky jejichž klíče mají ekvivalentní řazení (a které hash na stejnou hodnotu celé číslo) sousedících v sadě.Na rozdíl od šablony třídy hash_set (STL/CLR), objekt šablony třídy hash_multiset nevyžaduje, že jsou jedinečné klíče pro všechny prvky.(Dvou nebo více kláves můžete mít rovnocenné objednávání.)
Určuje objekt bloku, který by měl obsahovat daný klíč řazení voláním uložené delegát objekt typu hash_set::hasher (STL/CLR).Přístup k objektu uložených voláním funkce členské hash_set::hash_delegate (STL/CLR)() získání celočíselnou hodnotu, která závisí na hodnotě klíče.Můžete určit objekt uložených delegátem při konstrukci hash_set; Pokud nezadáte žádný objekt delegáta, ve výchozím nastavení je funkce System::Object::hash_value(key_type).To znamená pro všechny klíče X a Y:
hash_delegate()(X)Při každém volání vrátí stejný výsledek celé číslo.
Pokud X a Y mít rovnocenné objednávání, pak hash_delegate()(X) by vrátí stejný výsledek jako celé číslo hash_delegate()(Y).
Každý prvek slouží jako klíč 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čet operací, který je nezávislý na počtu prvků v posloupnosti (konstantní času)--alespoň v nejlepším případě.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.
Pokud hodnoty hash hodnoty nejsou distribuovány jednotně, však lze degenerate tabulky hash.V extrémních--pro funkci hash, který vždy vrátí stejnou hodnotu--vyhledávání, vkládání a odstraňování jsou úměrné počtu prvků v posloupnosti (lineární čas).Endeavors kontejner zvolit funkci hash přiměřené, plechovka střední velikost a velikost tabulky hash (celkový počet bloků), ale můžete změnit některé nebo všechny tyto volby.Viz například funkce hash_set::max_load_factor (STL/CLR) a hash_set::rehash (STL/CLR).
Hash_multiset podporuje obousměrný u iterátorů, což znamená, že můžete na sousedící prvky uvedené iterace, který určuje prvek řízené postupně krok.Zvláštní hlavního uzlu odpovídá iterační vrácené hash_multiset::end (STL/CLR)().Tento iterační dosáhnout poslední prvek v pořadí řízené lze snížit přítomen.Můžete zvýšit iterační hash_multiset k dosažení hlavního uzlu a potom bude porovnávat rovno end().Ale nelze zrušit reference struktury iterace vrácené end().
Všimněte si, že nelze odkazovat přímo dané číselné pozice--vyžadující iterační random access hash_multiset prvku.
Hash_multiset iterační uloží popisovač uzlu přidružené hash_multiset jeho zase uloží popisovač jeho přidružené kontejneru.U iterátorů lze použít pouze jejich přidružené kontejneru objektů.Hash_multiset iterační zůstává v platnosti tak dlouho, dokud je spojen s hash_multiset některé jeho přidružené hash_multiset uzlu.Kromě toho je platný iterační dereferencable – slouží k přístupu nebo změnit hodnotu prvku jmenuje--tak dlouho, dokud není rovno end().
Mazání nebo odebrání prvku volá jeho uložená hodnota se objekt.Zničení kontejneru vymaže všechny prvky.Kontejner, jehož typ prvku je třída ref tedy zajišťuje, že outlive žádné prvky kontejneru.Upozorňujeme však, že kontejner úchyty nemá not zničit jeho prvky.
Požadavky
Záhlaví: < cliext/hash_set >
Obor názvů: cliext