Sdílet prostřednictvím


unordered_map::operator

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

Ty& operator[](const Key& keyval);
Ty& operator[](Key&& keyval);

Parametry

Parametr

Description

Keyval

Hodnota klíče k vyhledání nebo vložit.

Vrácená hodnota

Odkaz na hodnotu dat vloženého prvku.

Poznámky

Pokud je argument hodnota klíče nebyl nalezen, pak je vložen spolu s výchozí hodnotu datového typu.

**operator[]**mohou být použity k vkládání prvků do mapy m pomocí m_klíčů =DataValue; kde DataValue je hodnota mapped_type prvku s hodnotu klíče _klíčů.

Při použití operator[] Chcete-li vložit prvků výsledného odkazu neznamená změna již existující prvek nebo vytvořením nového vložení.Funkce členů Najít a Vložit lze zjistit, zda prvek se zadaným klíčem již před vložení.

Příklad

// 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); 
    } 
 
  

Poznámky

Funkce člena určuje iterace where jako návratová hodnota unordered_map::insert( unordered_map::value_type(keyval, Ty()).(Vloží prvek se zadaným klíčem Pokud žádný takový prvek neexistuje.) Vrátí odkaz na (*where).second.

Požadavky

Záhlaví: <unordered_map>

Obor názvů: std

Viz také

Referenční dokumentace

<unordered_map>

unordered_map Class

unordered_map::find

unordered_map::insert

Další zdroje

<unordered_map> Členové