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,它基于平衡二叉搜索树实现,并保持了元素的插入顺序。

相关推荐
Molesidy23 分钟前
【随笔】【QT】QT5.15.2版本的最新下载方式!!!
开发语言·qt
二进制person1 小时前
Java EE初阶 --多线程2
java·开发语言
yue0081 小时前
C#理论学习-WinForm实践开发教程总结
开发语言·学习·c#
橙子家2 小时前
Serilog 日志库简单实践(二):控制台与调试 Sinks(.net8)
后端
007php0072 小时前
某游戏大厂 Java 面试题深度解析(四)
java·开发语言·python·面试·职场和发展·golang·php
Mr.Jessy2 小时前
Web APIs学习第一天:获取 DOM 对象
开发语言·前端·javascript·学习·html
午安~婉2 小时前
javaScript八股问题
开发语言·javascript·原型模式
想不明白的过度思考者2 小时前
Rust——异步递归深度指南:从问题到解决方案
开发语言·后端·rust
芝麻开门-新起点3 小时前
flutter 生命周期管理:从 Widget 到 State 的完整解析
开发语言·javascript·ecmascript
ConardLi4 小时前
Easy Dataset 已经突破 11.5K Star,这次又带来多项功能更新!
前端·javascript·后端