使用find()或count()判断键是否存在,推荐find()获取值;安全访问用at()或find()避免operator[]插入副作用。

在C++中,map 是一种基于红黑树实现的关联容器,用于存储键值对(key-value),并自动按键排序。查找 map 中的某个键以及安全地访问其值是常见操作。下面介绍几种常用且安全的方法。
find() 是最推荐的方式之一,用于判断某个键是否存在。
• 如果键存在,find() 返回指向该键值对的迭代器。示例代码:
#include <map>
#include <iostream>
std::map<std::string, int> scores;
scores["Alice"] = 95;
scores["Bob"] = 87;
auto it = scores.find("Alice");
if (it != scores.end()) {
std::cout << "Found: " << it->second << std::endl;
} else {
std::cout << "Key not found" << std::endl;
}
count() 返回指定键的出现次数。由于 map 中键唯一,结果只能是 0 或 1。
立即学习“C++免费学习笔记(深入)”;
• 适合仅需判断存在性,不需要立即获取值的场景。示例:
if (scores.count("Charlie")) {
std::cout << "Charlie exists" << std::endl;
} else {
std::cout << "Charlie does not exist" << std::endl;
}
operator[] 在键不存在时会自动插入该键,并用默认值初始化(如 int 为 0)。这可能导致意外创建元素。
• 若只是读取,不希望修改 map,应避免直接使用 []。更安全的替代方法:
• 使用 find() + 迭代器检查(如上所示)。示例:
try {
int value = scores.at("David"); // 若不存在则抛异常
std::cout << "Value: " << value << std::endl;
} catch (const std::out_of_range&) {
std::cout << "Key not present!" << std::endl;
}
以上就是c++++中如何查找map中的一个键_c++ map键查找与安全访问方法的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号