一、办法

1、通过[]获取

相似于拜访数组元素的形式。

std::map<int, string> mapInfo{ {1,"test"},{2,"lin"},{3,"wei"} };string strData = mapInfo[1];  std::cout << "strData: " << strData << std::endl;

后果如下:

留神:
1)只有当 map 容器中的确存有蕴含该指定键的键值对,借助重载的 [ ] 运算符能力胜利获取该键对应的值
2)若以后 map 容器中没有蕴含该指定键的键值对,则此时应用 [ ] 运算符将不再是拜访容器中的元素,而变成了向该 map 容器中削减一个键值对

std::map<int, string> mapInfo{ {1,"test"},{2,"lin"},{3,"wei"} };mapInfo[5] = "li";std::map<int, string>::iterator mapIter = mapInfo.begin();for (; mapIter != mapInfo.end(); mapIter++){    std::cout << "key: " << mapIter->first << " value: " << mapIter->second << std::endl;}

后果如下:

3)其中,该键值对的键用 [ ] 运算符中指定的键,其对应的值取决于 map 容器规定键值对中值的数据类型,如果是根本数据类型,则值为 0;如果是 string 类型,其值为 "",即空字符串(即应用该类型的默认值作为键值对的值)
4)[]具备增加新的键值对的前提是:以后map容器中不存在新增加的键
5)如map容器中已存在对应键,执行map[key] = value是批改键key的值,而不是为 map 容器增加新键值对

mapInfo[5] = "wne";mapIter = mapInfo.begin();for (; mapIter != mapInfo.end(); mapIter++){    std::cout << "mod key: " << mapIter->first << " value: " << mapIter->second << std::endl;}

后果如下:

2、at()

须要指定key,能力从容器中找到该键对应的值;如果在以后容器中查找失败,该办法不会向容器中增加新的键值对,而是间接抛出 out_of_range 异样。

std::map<int, string> mapInfo{ {1,"test"},{2,"lin"},{3,"wei"} };mapInfo[5] = "li";try{    std::cout << mapInfo.at(3) << std::endl;    std::cout << mapInfo.at(10) << std::endl;       }catch (const std::exception&){    std::cout << "调用at获取键对应的值异样" << std::endl;}

后果如下:

3、find

如果查找胜利,该迭代器指向查找到的键值对;反之,则指向 map 容器最初一个键值对之后的地位(和 end() 胜利办法返回的迭代器一样)。

std::map<int, string> mapInfo{ {1,"test"},{2,"lin"},{3,"wei"} };mapInfo[5] = "li";std::map<int, string>::iterator mapIter = mapInfo.find(5);if (mapIter != mapInfo.end()){    std::cout << mapIter->first << "  " << mapIter->second << std::endl;}

后果如下:

4、若以上办法都不能获取到值,那只能遍历整个map容器查找,进而获取值
具体代码在这里就不写了