c++怎么遍历unordered_map?unordered_map遍历方法有哪些

来源:站长联盟作者:松松建站头衔:草根站长
导读:本期聚焦于小伙伴创作的《c++怎么遍历unordered_map?unordered_map遍历方法有哪些》,敬请观看详情,探索知识的价值。以下视频、文章将为您系统阐述其核心内容与价值。如果您觉得《c++怎么遍历unordered_map?unordered_map遍历方法有哪些》有用,将其分享出去将是对创作者最好的鼓励。

在c++标准库中,unordered_map是基于哈希表实现的键值对容器,存储的元素是无序的,遍历它有多种不同的实现方式,开发者可以根据代码场景选择最合适的方法。

c++怎么遍历unordered_map?unordered_map遍历方法有哪些

迭代器遍历方式

迭代器是遍历unordered_map最基础的方式,通过获取容器的起始迭代器和结束迭代器,逐个访问元素。这种方式兼容性较好,支持c++11之前的版本。

#include <iostream>
#include <unordered_map>
#include <string>

int main() {
    // 创建并初始化unordered_map
    std::unordered_map<int, std::string> my_map;
    my_map[1] = "apple";
    my_map[2] = "banana";
    my_map[3] = "orange";

    // 使用迭代器遍历
    for (std::unordered_map<int, std::string>::iterator it = my_map.begin(); it != my_map.end(); ++it) {
        std::cout << "key: " << it->first << ", value: " << it->second << std::endl;
    }

    // c++11之后可以使用auto简化迭代器声明
    for (auto it = my_map.begin(); it != my_map.end(); ++it) {
        std::cout << "key: " << it->first << ", value: " << it->second << std::endl;
    }

    return 0;
}

范围for循环遍历

c++11引入了范围for循环,遍历unordered_map的代码会更加简洁,不需要手动声明迭代器,可读性更强。

#include <iostream>
#include <unordered_map>
#include <string>

int main() {
    std::unordered_map<int, std::string> my_map;
    my_map[1] = "apple";
    my_map[2] = "banana";
    my_map[3] = "orange";

    // 范围for循环遍历,元素类型为std::pair<const int, std::string>
    for (const auto& pair : my_map) {
        std::cout << "key: " << pair.first << ", value: " << pair.second << std::endl;
    }

    return 0;
}

结构化绑定遍历(c++17及以上)

c++17新增了结构化绑定特性,遍历unordered_map时可以直接将键值对拆分为独立的变量,不需要再通过first和second访问,代码更直观。

#include <iostream>
#include <unordered_map>
#include <string>

int main() {
    std::unordered_map<int, std::string> my_map;
    my_map[1] = "apple";
    my_map[2] = "banana";
    my_map[3] = "orange";

    // 结构化绑定遍历,直接获取key和value
    for (const auto& [key, value] : my_map) {
        std::cout << "key: " << key << ", value: " << value << std::endl;
    }

    return 0;
}

不同遍历方式的对比

下面通过表格对比几种遍历方式的特点,方便开发者选择:

遍历方式适用c++版本代码简洁度特点
迭代器遍历c++11之前及之后一般兼容性好,支持修改遍历过程中的迭代器位置
范围for循环c++11及以上较高代码简洁,不需要手动操作迭代器
结构化绑定遍历c++17及以上最高直接拆分键值对,可读性最强

遍历注意事项

  • unordered_map遍历时元素的顺序是不确定的,因为它是无序容器,遍历顺序和插入顺序没有关联。
  • 遍历过程中如果需要删除元素,使用迭代器遍历时可以通过erase方法返回下一个有效迭代器,避免迭代器失效。
  • 如果不需要修改元素内容,建议使用const引用接收遍历到的元素,减少不必要的拷贝开销。
注意:unordered_map的键是const类型,遍历过程中不能修改键的值,否则会破坏哈希表的结构,只能修改对应的值。

unordered_map遍历c++迭代器范围for循环修改时间:2026-07-02 23:45:23

免责声明:​ 已尽一切努力确保本网站所含信息的准确性。网站内容多为原创整理与精心编撰,观点力求客观中立。本站旨在免费分享,内容仅供个人学习、研究或参考使用。若引用了第三方作品,版权归原作者所有。如内容涉及您的权益,请联系我们处理。
内容垂直聚焦
专注技术核心技术栏目,确保每篇文章深度聚焦于实用技能。从代码技巧到架构设计,为用户提供无干扰的纯技术知识沉淀,精准满足专业提升需求。
知识结构清晰
覆盖从开发到部署的全链路。AI、前端、编程、数据库、服务器、建站、系统层层递进,构建清晰学习路径,帮助用户系统化掌握开发与运维所需的核心技术。
深度技术解析
拒绝泛泛而谈,深入技术细节与实践难点。无论是数据库优化还是服务器配置,均结合真实场景与代码示例进行剖析,致力于提供可直接应用于工作的解决方案。
专业领域覆盖
精准对应开发生命周期。从前端界面到后端编程,从数据库操作到服务器运维,形成完整闭环,一站式满足全栈工程师和运维人员的技术需求。
即学即用高效
内容强调实操性,步骤清晰、代码完整。用户可根据教程直接复现和应用于自身项目,显著缩短从学习到实践的距离,快速解决开发中的具体问题。
持续更新保障
专注既定技术方向进行长期、稳定的内容输出。确保各栏目技术文章持续更新迭代,紧跟主流技术发展趋势,为用户提供经久不衰的学习价值。