0

0

c++中如何使用unordered_map_c++哈希表容器用法详解

冰火之心

冰火之心

发布时间:2026-01-06 16:40:02

|

905人浏览过

|

来源于php中文网

原创

unordered_map需包含头文件,属std命名空间,底层为哈希表,平均O(1)、最坏O(n);声明为std::unordered_map,Key需支持==和哈希函数;operator[]会默认构造value,at()抛异常,insert/emplace不覆盖且返回插入结果;仅支持迭代器遍历,不维护顺序;建议预reserve避免rehash,合理设置max_load_factor优化性能。

c++中如何使用unordered_map_c++哈希表容器用法详解

unordered_map 的基本声明和头文件依赖

必须包含 头文件,且命名空间为 std。它不是传统顺序容器,不保证元素顺序,底层是哈希表实现,平均时间复杂度为 O(1) 的查找、插入、删除 —— 但最坏情况(大量哈希冲突)会退化到 O(n)。

声明格式为:std::unordered_map,日常使用只需前两个模板参数:

std::unordered_map word_count;
std::unordered_map id_to_name;

注意:Key 类型必须支持 == 比较,且必须有对应的哈希函数。内置类型(intlongstd::string 等)已提供特化,自定义结构体需手动提供 std::hash 特化或传入自定义 Hash 函数对象。

插入与访问:operator[]、insert 和 at 的区别

operator[] 最常用,但有副作用:若 key 不存在,会默认构造 value 并插入(对 int 是 0,对 std::string 是空串)。这在只读场景下容易误插脏数据。

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

  • word_count["hello"]++; → 若无 "hello",先插入 {"hello", 0},再 ++ 变成 1
  • word_count.at("hello") → 若 key 不存在,抛出 std::out_of_range 异常,适合明确要求 key 必须存在时
  • word_count.insert({key, value})word_count.emplace(key, value) → 不覆盖已有 key,返回 std::pairsecond 表示是否插入成功

推荐在计数类逻辑中用 operator[],在配置加载、映射查表等关键路径中优先用 at() 或检查 insert 返回值。

Speech Studio
Speech Studio

微软语音服务,提供语音到文本、文本到语音和语音翻译功能。

下载

遍历 unordered_map:为什么不能用下标?

unordered_map 不支持随机访问,没有 operator[] 以外的下标语法,也不能用 at(i)data()。只能通过迭代器遍历:

for (const auto& pair : word_count) {
    std::cout << pair.first << ": " << pair.second << "\n";
}

注意:pair.first 是 key,pair.second 是 value;若需修改 value,用 auto& 而非 const auto&;若要按 key 排序输出,得先拷贝到 std::vectorstd::sort —— 它本身不维护顺序。

另外,迭代器失效规则比 map 更宽松:只有触发 rehash(如 rehash() 或插入导致负载因子超限)时,所有迭代器才失效;单次 insert/erase 不会使其他迭代器失效(除非 rehash 发生)。

性能调优:load_factor、reserve 和 hash 冲突处理

默认最大负载因子是 1.0,即平均每个桶最多 1 个元素。当 size() / bucket_count() > max_load_factor() 时自动 rehash,开销较大。若已知最终规模,应提前 reserve(n)(分配至少能容纳 n 个元素的桶数),而非 resize(n)(那是 vector 的)。

  • word_count.reserve(10000); → 避免多次 rehash
  • word_count.max_load_factor(0.75); → 主动降低负载以减少冲突(但增加内存占用
  • 若自定义类型作 key 且哈希分布差(如全返回 0),会导致单链过长,退化为链表查找 —— 此时必须重写哈希函数,不能只重载 operator==

调试时可打印 word_count.load_factor()word_count.bucket_count() 观察实际分布。真正影响性能的往往不是哈希函数本身,而是 key 的实际分布是否均匀 —— 比如用连续整数作 key,std::hash 是良构的;但用指针地址作 key,在 ASLR 下可能集中于某几段值域,仍需谨慎。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

314

2023.08.02

sort排序函数用法
sort排序函数用法

sort排序函数的用法:1、对列表进行排序,默认情况下,sort函数按升序排序,因此最终输出的结果是按从小到大的顺序排列的;2、对元组进行排序,默认情况下,sort函数按元素的大小进行排序,因此最终输出的结果是按从小到大的顺序排列的;3、对字典进行排序,由于字典是无序的,因此排序后的结果仍然是原来的字典,使用一个lambda表达式作为key参数的值,用于指定排序的依据。

381

2023.09.04

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

520

2023.09.20

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

194

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

186

2025.07.04

golang结构体相关大全
golang结构体相关大全

本专题整合了golang结构体相关大全,想了解更多内容,请阅读专题下面的文章。

194

2025.06.09

golang结构体方法
golang结构体方法

本专题整合了golang结构体相关内容,请阅读专题下面的文章了解更多。

186

2025.07.04

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

314

2023.08.02

java成品网站源码资源大全
java成品网站源码资源大全

本专题整合了java成品网站源码相关内容,阅读专题下面的文章了解更多详细内容。

2

2026.01.08

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
10分钟--Midjourney创作自己的漫画
10分钟--Midjourney创作自己的漫画

共1课时 | 0.1万人学习

Midjourney 关键词系列整合
Midjourney 关键词系列整合

共13课时 | 0.9万人学习

AI绘画教程
AI绘画教程

共2课时 | 0.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号