unordered_map::operator
Localiza ou insere um elemento com a chave especificada.
Ty& operator[](const Key& keyval);
Ty& operator[](Key&& keyval);
Parâmetros
Parâmetro |
Descrição |
Keyval |
O valor da chave para localizar ou inserir. |
Valor de retorno
Uma referência ao valor de dados do elemento inserido.
Comentários
Se o valor da chave de argumento não for encontrado, ele é inserido junto com o valor padrão do tipo de dados.
**operator[]**pode ser usado para inserir elementos em um mapa m usando m_chave =DataValue; onde DataValue é o valor da mapped_type do elemento com um valor de chave de _chave.
Ao usar o operator[] para inserir elementos, a referência fornecida não indica se uma inserção é a alteração de um elemento pré-existente ou criando um novo.As funções de membro Localizar e Inserir pode ser usado para determinar se um elemento com uma chave especificada já está presente antes uma inserção.
Exemplo
// std_tr1__unordered_map__unordered_map_operator_sub.cpp
// compile with: /EHsc
#include <unordered_map>
#include <iostream>
#include <string>
typedef std::unordered_map<char, int> Mymap;
int main()
{
Mymap c1;
c1.insert(Mymap::value_type('a', 1));
c1.insert(Mymap::value_type('b', 2));
c1.insert(Mymap::value_type('c', 3));
// display contents " [c 3] [b 2] [a 1]"
for (Mymap::const_iterator it = c1.begin();
it != c1.end(); ++it)
std::cout << " [" << it->first << ", " << it->second << "]";
std::cout << std::endl;
// try to find and fail
std::cout << "c1['A'] == " << c1['A'] << std::endl;
// try to find and succeed
std::cout << "c1['a'] == " << c1['a'] << std::endl;
// redisplay contents
for (Mymap::const_iterator it = c1.begin();
it != c1.end(); ++it)
std::cout << " [" << it->first << ", " << it->second << "]";
std::cout << std::endl;
// insert by moving key
std::tr1::unordered_map<string, int> c2;
std::string str("abc");
std::cout << "c2[std::move(str)] == " << c2[std::move(str)] << std::endl;
std::cout << "c2["abc"] == " << c2["abc"] << std::endl;
return (0);
}
Comentários
A função de membro determina o iterador where como o valor de retorno de unordered_map::insert( unordered_map::value_type(keyval, Ty()).(Ele insere um elemento com a chave especificada se não há tal elemento existe.) Em seguida, ele retorna uma referência a (*where).second.
Requisitos
Cabeçalho: <unordered_map>
Namespace: std