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 的基本声明和头文件依赖

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

声明格式为:std::unordered_map<key t hash keyequal allocator></key>,日常使用只需前两个模板参数:

std::unordered_map<std::string, int> word_count;
std::unordered_map<int, std::string> 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::pair<iterator bool></iterator>second 表示是否插入成功

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

Quinvio AI
Quinvio AI

AI辅助下快速创建视频,虚拟代言人

下载

遍历 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<int></int> 是良构的;但用指针地址作 key,在 ASLR 下可能集中于某几段值域,仍需谨慎。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

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

1010

2023.08.02

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

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

409

2023.09.04

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

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

562

2023.09.20

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

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

490

2025.06.09

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

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

202

2025.07.04

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

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

490

2025.06.09

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

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

202

2025.07.04

string转int
string转int

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

1010

2023.08.02

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
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号