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: 標準