STLRecipe---map

map對(duì)象

map<K,T>類模板定義在map文件頭中,它定義了一個(gè)保存T 類型對(duì)象的 map,每個(gè) T類型的對(duì)象都有一個(gè)關(guān)聯(lián)的K類型的鍵。容器內(nèi)對(duì)象的位置是通過(guò)比較鍵決定的??梢杂眠m當(dāng)?shù)逆I值從map容器中檢索對(duì)象。

  • 創(chuàng)建map
std::map<std::string, size_t> people;
std::map<std::string, size_t> people{{"Ann", 25}, {"Bill", 46},{"Jack", 32},{"Jill", 32}};
  1. utility 頭文件中定義了 make_pair < T1,T2 >()函數(shù)模板,它提供了一種組合 T1T2類型對(duì)象的簡(jiǎn)單方法。因此,可以按如下方式創(chuàng)建 pair 對(duì)象來(lái)初始化 map:
std::map<std::string,size_t> people{std::make_pair("Ann",25),std::make_pair("Bill", 46),std::make_pair("Jack", 32),std::make_pair("Jill", 32)};

  1. 復(fù)制現(xiàn)有的容器:
std::map<std::string, size_t> personnel {people}; // Duplicate people map
  1. 用另一個(gè)容器的一段元素來(lái)創(chuàng)建一個(gè) map
std::map<std::string, size_t> personnel {std::begin(people),std::end(people)};
std::map<std::string,size_t> personnel {++std::begin(people),std::end(people)};
  • map插入數(shù)據(jù)
    map<K,T>容器的成員函數(shù)insert()有多個(gè)版本,它們可以在 map 中插入一個(gè)或多個(gè) pair<const K,T> 對(duì)象。只能插入map中不存在的元素。
std::map<std:: string,size_t> people {std::make_pair ("Ann",25),std::make_pair("Bill",46) , std::make_pair ("Jack",32), std::make_pair("Jill",32)};
auto pr = std::make_pair("Fred",22); //Create a pair element and insert it
auto ret_pr = people.insert(pr);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容