unordered_multimap Class
Klasa szablonu opisuje obiekt, który kontroluje sekwencji różnej długości elementów typu std::pair<const Key, Ty>.Sekwencja jest słabo uporządkowane według funkcji mieszania, partycje sekwencji w uporządkowany zestaw o nazwie segmentów podciągów.W ramach każdego segmentu funkcji porównania określa, czy para żadnych elementów ma, równoważne zamawiania.Każdy element przechowuje dwa obiekty, klucz sortowania i wartości.Sekwencja jest reprezentowana w sposób, który pozwala na wyszukiwanie, wstawiania i usuwania dowolnego elementu, o liczbie operacji, które mogą być niezależne od liczby elementów w sekwencji (czas stałej), co najmniej po wszystkich segmentów są przybliżeniu równej długości.W najgorszym przypadku, gdy wszystkie elementy są w jednym segmencie liczba operacji jest proporcjonalna do liczby elementów w sekwencji (liniowy czasu).Ponadto Wstawianie elementu unieważnia Iteratory nie i usuwanie elementu unieważnia tylko Iteratory, które wskazują na element usunięty.
template<class Key,
class Ty,
class Hash = std::tr1::hash<Key>,
class Pred = std::equal_to<Key>,
class Alloc = std::allocator<Key> >
class unordered_multimap;
Parametry
Parametr |
Opis |
Key |
Typ klucza. |
Ty |
Typ mapowane. |
Hash |
Typ obiektu funkcji mieszania. |
Pred |
Typ obiektu funkcji porównania równości. |
Alloc |
Klasa przydzielania. |
Członkowie
Definicja typu |
Opis |
Typ programu przydzielania zarządzania przechowywania. |
|
Typ stałej iteratora kontrolowanych sekwencji. |
|
Typ iteratora stałej segmentu dla kontrolowanych sekwencji. |
|
Typ stałej wskaźnik do elementu. |
|
Typ stałej odwołanie do elementu. |
|
Typ podpisane odległość między dwoma elementami. |
|
Typ funkcji mieszania. |
|
Typ iterację kontrolowanych sekwencji. |
|
Typ funkcji porównania. |
|
Typ sortowania klucza. |
|
Typ iteratora segmentu dla kontrolowanych sekwencji. |
|
Typ mapowane wartości skojarzonych z poszczególnymi kluczami. |
|
Typ wskaźnika do elementu. |
|
Typ odwołania do elementu. |
|
Typ niepodpisane odległość między dwoma elementami. |
|
Typ elementu. |
Funkcja Członkowskie |
Opis |
Określa początek kontrolowanych sekwencji. |
|
Pobiera numer segmentu dla wartości klucza. |
|
Pobiera ilość segmentów. |
|
Pobiera rozmiar segmentu. |
|
Określa początek kontrolowanych sekwencji. |
|
Wyznacza koniec sekwencji kontrolowane. |
|
Usuwa wszystkie elementy. |
|
Wyszukuje liczbę elementów pasujących do określonego klucza. |
|
Dodaje element w miejscu. |
|
Dodaje element zbudowanych w miejscu wskazówkę. |
|
Badania, czy elementy nie są obecnie. |
|
Wyznacza koniec sekwencji kontrolowane. |
|
Wyszukuje zakres, który pasuje do określonego klucza. |
|
Usuwa elementy na określonych pozycjach. |
|
Znajduje element, który pasuje do określonego klucza. |
|
Zwraca obiekt alokatora przechowywane. |
|
Pobiera obiekt funkcji mieszania przechowywane. |
|
Dodaje elementy. |
|
Pobiera obiekt przechowywane porównanie funkcji. |
|
Oblicza średnią elementów na Wiadro z farbą. |
|
Pobiera maksymalna liczba segmentów. |
|
Pobiera lub ustawia maksymalną elementów na Wiadro z farbą. |
|
Pobiera maksymalny rozmiar kontrolowany sekwencji. |
|
Przebudowuje tabeli mieszania. |
|
Zlicza liczbę elementów. |
|
Zamienia zawartość dwóch kontenerów. |
|
Konstrukcje obiektu kontenera. |
Operator |
Opis |
Kopiuje z tabeli mieszania. |
Uwagi
Obiekt zamówienia sekwencji kontroluje, wywołując dwóch obiektów przechowywanych porównanie funkcji obiektu typu unordered_multimap::key_equal i obiektu funkcji mieszania typu unordered_multimap::hasher.Dostęp do pierwszego obiektu przechowywanych przez wywołanie funkcji Członkowskich unordered_multimap::key_eq(); i dostępu do drugiego obiektu przechowywanych przez wywołanie funkcji Członkowskich unordered_multimap::hash_function().W szczególności dla wszystkich wartości X i Y typu Key, wywołanie key_eq()(X, Y) zwraca wartość true tylko wtedy, gdy wartości argumentu dwóch równoważnych zamówienia; wywołanie hash_function()(keyval) daje dystrybucji wartości typu size_t.W odróżnieniu od szablonu klasy unordered_map Class, obiekt szablonu klasy unordered_multimap nie zapewnia, że key_eq()(X, Y) jest zawsze wartość false dla dwóch elementów kontrolowanych sekwencji.(Klawisze nie musi być unikatowy.)
Obiekt przechowuje również czynnik maksymalnego obciążenia określa, że maksymalne potrzeby średnia liczba elementów na Wiadro z farbą.Jeżeli powoduje wstawienie elementu unordered_multimap::load_factor() przekracza współczynnik maksymalnego obciążenia, kontener zwiększa ilość segmentów i odtwarza tabeli mieszania, w razie potrzeby.
Rzeczywistej kolejności elementów w sekwencji kontrolowanych zależy od funkcji mieszania, funkcja porównania, kolejność wstawiania, współczynnik maksymalnego obciążenia i bieżąca liczba segmentów.Kolejność elementów w sekwencji kontrolowanych w ogóle nie można przewidzieć.Można zawsze mieć pewność, jednak sąsiadujących dowolny podzestaw elementów równoważnych zamawiania kontrolowanych sekwencji.
Obiekt przydziela i zwalnia przechowywania sekwencji kontroluje za pośrednictwem obiektu przechowywane alokatora typu unordered_multimap::allocator_type.Obiekt programu przydzielania muszą mieć ten sam interfejs zewnętrzny jako obiekt szablonu klasy allocator.Należy zauważyć, że przypisany obiekt kontenera obiektu alokatora przechowywanych nie jest kopiowane.
Wymagania
Nagłówek: <unordered_map>
Obszar nazw: std