Rust 的 HashMap

在 Rust 中,HashMap 是一个从键(key)映射到值(value)的数据结构。它允许你以 O(1) 的平均时间复杂度存储、检索和删除键值对。HashMap 实现了 std::collections::HashMap 结构体,通常通过 use std::collections::HashMap; 语句引入。

下面是一个使用 Rust 的 HashMap 的基本示例:

rust 复制代码
use std::collections::HashMap;

fn main() {
    // 创建一个空的 HashMap
    let mut scores = HashMap<String, i32>::new();

    // 向 HashMap 中插入键值对
    scores.insert("Blue", 10);
    scores.insert("Yellow", 50);

    // 通过键获取值(如果键不存在,则返回 None)
    if let Some(score) = scores.get("Blue") {
        println!("Blue: {}", score);
    }

    // 更新一个已存在的键的值
    scores.insert("Blue", 25);

    // 遍历 HashMap 中的键值对
    for (key, value) in &scores {
        println!("{}: {}", key, value);
    }

    // 检查 HashMap 是否包含某个键
    if scores.contains_key("Red") {
        println!("Red is in the HashMap!");
    } else {
        println!("Red is not in the HashMap.");
    }

    // 从 HashMap 中移除一个键值对
    scores.remove("Yellow");

    // 获取 HashMap 的大小(键值对的数量)
    println!("Size of scores: {}", scores.len());
}

在这个例子中,我们创建了一个 HashMap 来存储颜色和其对应的分数。我们使用了 insert 方法来添加键值对,get 方法来获取一个键对应的值(返回 Option<V> 类型,因为键可能不存在),contains_key 方法来检查 HashMap 是否包含某个键,以及 remove 方法来删除一个键值对。我们还使用了 for 循环来遍历 HashMap 中的所有键值对,并打印它们。最后,我们使用 len 方法来获取 HashMap 的大小。

注意,HashMap 的键(Key)类型必须实现 EqHash trait,这样 Rust 才能知道如何比较键以及为它们生成哈希值。大多数标准库中的类型都自动实现了这些 trait,因此你可以直接使用它们作为 HashMap 的键。如果你需要自定义类型作为键,你需要确保为你的类型实现这些 trait。

另外,由于 HashMap 是基于哈希表的,它的元素是无序的。如果你需要有序的键值对集合,可以考虑使用 BTreeMap,它基于平衡二叉搜索树实现,并保持了元素的插入顺序。

相关推荐
fish_xk4 小时前
c++中的引用和数组
开发语言·c++
酒尘&6 小时前
JS数组不止Array!索引集合类全面解析
开发语言·前端·javascript·学习·js
无限大67 小时前
计算机十万个为什么--数据库索引
后端
冬夜戏雪7 小时前
【java学习日记】【2025.12.7】【7/60】
java·开发语言·学习
xwill*7 小时前
分词器(Tokenizer)-sentencepiece(把训练语料中的字符自动组合成一个最优的子词(subword)集合。)
开发语言·pytorch·python
学历真的很重要7 小时前
VsCode+Roo Code+Gemini 2.5 Pro+Gemini Balance AI辅助编程环境搭建(理论上通过多个Api Key负载均衡达到无限免费Gemini 2.5 Pro)
前端·人工智能·vscode·后端·语言模型·负载均衡·ai编程
咖啡の猫7 小时前
Python列表的查询操作
开发语言·python
Eighteenzi7 小时前
REVM 解析 3 --- 新版本v97 的解析
rust·revm
quikai19818 小时前
python练习第三组
开发语言·python
JIngJaneIL8 小时前
基于Java非遗传承文化管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot