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 #include int main() {    std::map ageMap;    ageMap["Alice"] = 25;    ageMap["Bob"] = 30;
std::cout << "Alice's age: " << ageMap["Alice"] << std::endl; // 输出 25std::cout << "Charlie's age: " << ageMap["Charlie"] << std::endl; // 插入 Charlie,默认值 0return 0;

}

2. 使用 find() 方法

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

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

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

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

示例:

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

}

3. 使用 at() 方法

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

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

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

示例:

#include #include #include int main() {    std::map ageMap;    ageMap["Alice"] = 25;
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() 提供异常保护。按需选择即可。

以上就是c++++ map如何根据key查找value_c++ map按key查找方法的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1480696.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 04:52:06
下一篇 2025年12月19日 04:52:18

相关推荐

发表回复

登录后才能评论
关注微信