Classe unordered_map
A classe de modelo descreve um objeto que controla uma sequência de comprimento diferentes de elementos do tipo std::pair<const Key, Ty>. A sequência é weakly ordenados por uma função de hash, a sequência em um conjunto ordenado de subseqüências chamado buckets partições.Dentro de cada bucket uma função de comparação determina se qualquer emparelhar de elementos tem equivalente de pedidos.Cada elemento armazena dois objetos, uma chave de classificar e um valor.A sequência é representada de forma que permite a pesquisa, inserção e remoção de um elemento arbitrário com um número de operações que pode ser independente do número de elementos na sequência (time constante), pelo menos quando todos os depósitos são aproximadamente o mesmo comprimento.Na pior das hipóteses, quando todos os elementos estão em um compartimento de memória, o número de operações é proporcional ao número de elementos em sequência (time linear).Além disso, inserir um elemento não invalida nenhum iteradores e remover um elemento invalida os iteradores que aponta para o elemento removido.
template<class Key,
class Ty,
class Hash = std::tr1::hash<Key>,
class Pred = std::equal_to<Key>,
class Alloc = std::allocator<Key> >
class unordered_map;
Parâmetros
Parâmetro |
Descrição |
---|---|
Key |
O tipo de chave. |
Ty |
O tipo mapeado. |
Hash |
O tipo de objeto de função de hash. |
Pred |
O tipo de objeto de função de comparação de igualdade. |
Alloc |
A classe do alocador. |
Membros
Definição de tipo |
Descrição |
---|---|
O tipo de um alocador de gerenciamento de armazenamento. |
|
O tipo de um iterador constante para a sequência controlado. |
|
O tipo de um iterador constante bucket para a sequência controlado. |
|
O tipo de um ponteiro constante para um elemento. |
|
O tipo de uma referência constante a um elemento. |
|
O tipo de uma distância entre dois elementos assinado. |
|
O tipo de função de hash. |
|
O tipo de um iterador para a sequência controlado. |
|
O tipo da função de comparação. |
|
O tipo de uma chave de classificação. |
|
O tipo de um iterador bucket para a sequência controlado. |
|
O tipo de um valor mapeado associado a cada chave. |
|
O tipo de um ponteiro para um elemento. |
|
O tipo de uma referência a um elemento. |
|
O tipo de uma distância entre dois elementos não assinado. |
|
O tipo de um elemento. |
Função de membro |
Descrição |
---|---|
Designa o início da sequência controlado. |
|
Obtém o número de partição de memória para um valor de chave. |
|
Obtém o número de compartimentos de memória. |
|
Obtém o dimensionar de um depósito. |
|
Remove todos os elementos. |
|
Localiza o número de elementos de correspondência de uma chave especificada. |
|
Testes se sem elementos estão presentes. |
|
Designa o participante da sequência de controlado. |
|
Localiza o intervalo que corresponde a uma chave especificada. |
|
Remove os elementos em posições especificadas. |
|
Localiza um elemento que coincida com uma chave especificada. |
|
Obtém o objeto alocador armazenado. |
|
Obtém o objeto de função de hash armazenado. |
|
Adiciona elementos. |
|
Obtém o objeto de função de comparação armazenado. |
|
Conta os elementos médio por partição de memória. |
|
Obtém o número máximo de compartimentos de memória. |
|
Obtém ou define os elementos máximo por partição de memória. |
|
Obtém o dimensionar máximo da sequência controlado. |
|
Recria a tabela de hash. |
|
Conta o número de elementos. |
|
Troca o Sumário de dois recipientes. |
|
Constrói um objeto de contêiner. |
Operador |
Descrição |
---|---|
Localizar ou insere um elemento com a chave especificada. |
Comentários
O objeto ordena a sequência controla chamando dois objetos armazenados, um objeto de função de comparação do tipo unordered_map::key_equal e um objeto de função de hash do tipo unordered_map::hasher. Você acessar o primeiro objeto armazenado chamando a função de membro unordered_map::key_eq(); e acessar o segundo objeto armazenado chamando a função de membro unordered_map::hash_function(). Especificamente, para todos os valores de X e Y do tipo Key, a telefonar key_eq()(X, Y) Retorna true somente se têm os valores de dois argumento pedidos equivalente; a telefonar hash_function()(keyval) produz uma distribuição de valores de tipo size_t. Ao contrário do modelo de classe Classe unordered_multimap, um objeto de classe de modelo unordered_map garante que key_eq()(X, Y) é sempre falso para qualquer elemento da sequência controlado de dois. (As chaves são exclusivas.)
O objeto também armazena um fator de carga máxima, que especifica que o número máximo desejado número médio de elementos por partição de memória.Se inserir um elemento faz com que unordered_map::load_factor() para superar o fator de carga máxima, o contêiner aumenta o número de compartimentos de memória e recria a tabela de hash, conforme necessário.
A ordem real dos elementos na sequência controlado depende a função de hash, a função de comparação, a ordem de inserção, o fator de carga máxima e o número corrente de partições de memória.Em geral, você não pode prever a ordem dos elementos na sequência controlado.Você pode sempre ter certeza, no entanto, que são adjacentes na sequência controlada qualquer subconjunto de elementos que possuem pedidos equivalente.
O objeto aloca e libera o armazenamento para a sequência controlados por ele por meio de um objeto armazenado alocador do tipo unordered_map::allocator_type. Tal objeto alocador deve ter a mesma interface externa sistema autônomo um objeto de classe de modelo allocator. Observe que o objeto alocador armazenado não é copiado quando o objeto contêiner é atribuído.
Requisitos
Cabeçalho:<unordered_map>
Namespace: std::tr1