推荐使用find()或C++20的contains()检查map中key是否存在:find()效率高,适用于所有版本;contains()语义清晰,需C++20支持;count()可读性好但性能稍低;避免用operator[]判断存在性以防误插入。
在C++中,检查一个key是否存在于map中是一个常见操作。标准库中的std::map提供了多种方式来安全高效地完成这一任务。以下是几种常用且推荐的方法。
find() 是最推荐的方式之一,因为它只进行一次查找操作,效率高。
find() 返回指向该元素的迭代器;否则返回 map.end()。示例代码:
#include
count() 返回指定key的出现次数。由于map中每个key唯一,结果只能是0或1。
find(),因为内部仍需遍历查找。示例代码:
if (myMap.count(1)) {
std::cout << "Key 1 exists" << std::endl;
} else {
std::cout << "Key 1 does not exist" << std::endl;
}
C++20 引入了 contains() 成员函数,专门用于检查key是否存在,语义更清晰。
find() 更直观,无需比较迭代器。示例代码:
#if __cplusplus >= 202502L
if (myMap.contains(1)) {
std::cout << "Key exists in C++20" << std::endl;
}
#endif
不要用 myMap[key] 来判断key是否存在,因为如果key不存在,operator[] 会自动插入该key并用默认值初始化,这可能导致意外的数据修改。
operator[]。基本上就这些。日常开发中推荐使用 find() 或 C++20 的 contains(),兼顾效率与可读性。