共用方式為


unordered_map::operator[]

尋找,或將項目插入指定的索引鍵。

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

參數

參數

描述

Keyval

若要尋找] 或 [插入索引鍵的值。

傳回值

資料的值插入的項目參考。

備註

如果找不到引數機碼值,它會插入與資料型別的預設值。

operator[]可用於項目插入地圖 m 使用 m_機碼 =DataValue。 其中DataValue的值mapped_type _ 索引鍵值的項目機碼

當使用**operator[]**若要插入項目,傳回的參考不表示變更已存在的項目或建立一個新的插入。 成員函式插入可用來判斷具有指定索引鍵的項目是否已經存在之前插入。

範例

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

備註

成員函式會判斷 iterator where的傳回值為unordered_map::insert( unordered_map::value_type(keyval, Ty())。 (它會插入項目具有指定之索引鍵如果沒有這類項目。) 然後會傳回參考(*where).second。

需求

標頭: <unordered_map>

Namespace: 標準

請參閱

參考

<unordered_map>

unordered_map Class

unordered_map::find

unordered_map::insert

其他資源

<unordered_map> 成員