C++中map是基于红黑树的关联容器,自动按键排序存储键值对。需包含<map>头文件,支持insert、下标、emplace插入;可用下标、find、at访问;支持迭代器遍历和erase删除;常用函数有size、empty、clear、count,适用于高效查找与有序场景。

在C++中,map 是一个非常实用的关联容器,用于存储键值对(key-value pairs),并能根据键快速查找对应的值。它底层通常基于红黑树实现,元素会按照键自动排序。下面介绍 map 的基本使用方法,帮助你快速上手。
使用 map 前需要包含头文件 <map>,然后可以定义不同类型的 map:
#include <map>std::map<KeyType, ValueType> myMap;例如,创建一个以字符串为键、整数为值的 map:
std::map<std::string, int> ageMap;
向 map 中添加数据有多种方法:
立即学习“C++免费学习笔记(深入)”;
ageMap.insert(std::make_pair("Alice", 25));
ageMap["Bob"] = 30;ageMap.emplace("Charlie", 35);
可以通过键来获取对应的值:
int aliceAge = ageMap["Alice"];
auto it = ageMap.find("Alice");
if (it != ageMap.end()) {
std::cout << it->first << ": " << it->second << std::endl;
}try { int val = ageMap.at("Alice"); } catch(...) { }map 中的元素按键有序排列,可用迭代器或范围 for 循环遍历:
for (const auto& pair : ageMap) {
std::cout << pair.first << " - " << pair.second << std::endl;
}也可以使用迭代器:
for (auto it = ageMap.begin(); it != ageMap.end(); ++it) {
std::cout << it->first << ": " << it->second << std::endl;
}可以按键或迭代器删除元素:
ageMap.erase("Bob"); // 删除键为 "Bob" 的元素auto it = ageMap.find("Alice"); if (it != ageMap.end()) ageMap.erase(it);基本上就这些。map 使用起来直观高效,特别适合需要按键查找、自动排序的场景。注意避免用下标访问不存在的键导致意外插入,默认构造可能带来性能或逻辑问题。掌握 insert、find 和遍历方式,就能应对大多数情况。
以上就是C++如何使用map_C++ map使用方法的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号