c++ map如何根据key查找value_c++ map按key查找方法

c++中查找std::map键值有四种方法:1. operator[]直接访问,但会插入不存在的key;2. find()返回迭代器,安全且不修改map;3. at()提供异常安全访问;4. count()判断key是否存在。

c++ map如何根据key查找value_c++ map按key查找方法

在C++中,std::map 是一个关联容器,用于存储键值对(key-value pairs),并且按键(key)自动排序。要根据 key 查找对应的 value,有几种常用方法,每种方式适用不同场景。

1. 使用 operator[]

通过 map[key] 可以直接访问对应 key 的 value。

如果 key 存在,返回对应的 value;如果 key 不存在,会自动插入该 key,并用默认值初始化 value(例如 int 默认为 0)。

注意:这种方式可能无意中修改 map 内容。

示例:

#include <map> #include <iostream> int main() {     std::map<std::string, int> ageMap;     ageMap["Alice"] = 25;     ageMap["Bob"] = 30; <pre class="brush:php;toolbar:false;"><pre class="brush:php;toolbar:false;">std::cout << "Alice's age: " << ageMap["Alice"] << std::endl; // 输出 25 std::cout << "Charlie's age: " << ageMap["Charlie"] << std::endl; // 插入 Charlie,默认值 0 return 0;

}

2. 使用 find() 方法

调用 find(key) 返回一个迭代器。

如果找到,返回指向键值对的迭代器;否则返回 map.end()

立即学习C++免费学习笔记(深入)”;

推荐用于只读查找,不会修改 map。

示例:

#include <map> #include <iostream> int main() {     std::map<std::string, int> ageMap;     ageMap["Alice"] = 25;     ageMap["Bob"] = 30; <pre class="brush:php;toolbar:false;"><pre class="brush:php;toolbar:false;">auto it = ageMap.find("Alice"); if (it != ageMap.end()) {     std::cout << "Found: " << it->first << " - " << it->second << std::endl; } else {     std::cout << "Key not found." << std::endl; } return 0;

}

3. 使用 at() 方法

调用 at(key) 返回对应 key 的引用。

如果 key 不存在,会抛出 std::out_of_range 异常。

c++ map如何根据key查找value_c++ map按key查找方法

法语写作助手

法语助手旗下的AI智能写作平台,支持语法、拼写自动纠错,一键改写、润色你的法语作文。

c++ map如何根据key查找value_c++ map按key查找方法31

查看详情 c++ map如何根据key查找value_c++ map按key查找方法

适合需要安全访问且确定 key 存在的场景。

示例:

#include <map> #include <iostream> #include <stdexcept> int main() {     std::map<std::string, int> ageMap;     ageMap["Alice"] = 25; <pre class="brush:php;toolbar:false;"><pre class="brush:php;toolbar:false;">try {     std::cout << "Alice's age: " << ageMap.at("Alice") << std::endl;     std::cout << "Charlie's age: " << ageMap.at("Charlie") << std::endl; // 抛异常 } catch (const std::out_of_range& e) {     std::cout << "Key not found: " << e.what() << std::endl; } return 0;

}

4. 使用 count() 判断 key 是否存在

map 的 count(key) 返回 0 或 1(因为 key 唯一)。

可用于判断 key 是否存在,再决定是否访问。

示例:

if (ageMap.count("Alice")) {     std::cout << "Value: " << ageMap["Alice"] << std::endl; } 

基本上就这些。日常使用中,find() 最安全,operator[] 最方便但小心副作用,at() 提供异常保护。按需选择即可。

上一篇
下一篇
text=ZqhQzanResources