Rust HashMap :当储物袋遇上物品清单

请添加图片描述

开场白:哈希映射的魔法本质

在Rust的奇幻世界里,HashMap就像魔法师的储物袋:

  • 键值对存储 → 每个物品都有专属咒语(键)和实体(值)
  • 快速查找 → 念咒瞬间召唤物品
  • 动态扩容 → 自动伸展的魔法空间
  • 所有权规则 → 严格的物品保管条例
use std::collections::HashMap;let mut magic_pocket = HashMap::new(); // 打开新储物袋
magic_pocket.insert(String::from("🔥"), "火焰咒卷轴"); // 放入第一件宝物

第一章:基础操作三连击

1.1 物品收纳术(插入键值对)

场景类比:往魔法书里记录新咒语

let mut spell_book = HashMap::new();
spell_book.insert("💧".to_string(), "寒冰箭");  // 插入水元素咒语
spell_book.insert("🌪️".to_string(), "龙卷风"); // 插入风元素咒语println!("{:?}", spell_book);
// 输出:{"💧": "寒冰箭", "🌪️": "龙卷风"}

魔法原理

  • insert像挥动魔杖把物品送入口袋
  • 键和值会被口袋接管所有权(String类型)
  • 重复插入相同键会触发覆盖效果

1.2 精准召唤术(获取值)

场景类比:用特定咒语召唤对应物品

let water_spell = spell_book.get("💧");      // 精确查找
let unknown_spell = spell_book.get("⚡");    // 查找不存在的咒语println!("水咒语:{:?}", water_spell);    // Some("寒冰箭")
println!("雷咒语:{:?}", unknown_spell); // None

魔法原理

  • get方法返回Option<&V>类型
  • 返回的是不可变借用,物品仍属于口袋
  • 使用&str进行查找避免所有权转移

1.3 全物品扫描(遍历)

场景类比:清点魔法口袋所有物品

for (spell_symbol, spell_name) in &spell_book {println!("符咒{} => {}", spell_symbol, spell_name);
}
/* 输出:
符咒💧 => 寒冰箭
符咒🌪️ => 龙卷风
*/

魔法原理

  • 借用遍历避免转移所有权
  • 遍历顺序是随机的(魔法世界的混沌特性)

第二章:高级黑魔法(更新操作)

2.1 覆盖诅咒(直接覆盖)

场景类比:升级已有咒语

spell_book.insert("💧".to_string(), "极寒风暴"); // 覆盖原有咒语
println!("升级后:{:?}", spell_book.get("💧")); // Some("极寒风暴")

黑暗警示

  • 简单暴力但可能丢失重要数据
  • 适合需要强制更新的场景

2.2 条件封印(entry API)

场景类比:只有在没有对应咒语时才记录新咒语

spell_book.entry("⚡".to_string()).or_insert("雷电锁链"); // 因为⚡不存在,插入新咒语spell_book.entry("💧".to_string()).or_insert("绝对零度"); // 💧已存在,不执行操作println!("当前咒语表:{:?}", spell_book);
// ⚡被添加,💧保持"极寒风暴"

神谕指引

  • entry检查物品是否存在
  • or_insert只在空缺时执行
  • 避免无意义的覆盖

2.3 炼金合成(修改现有值)

场景类比:强化已有装备属性

let mut weapon_stats = HashMap::new();
weapon_stats.insert("圣剑", 100);// 找到条目并强化
weapon_stats.entry("圣剑").and_modify(|atk| *atk += 50).or_insert(100);println!("强化结果:{:?}", weapon_stats); // {"圣剑": 150}

炼金法则

  • and_modify允许修改现有值
  • 链式调用结合条件判断
  • 适合计数类场景

终章:综合大魔法——冒险者商店系统

use std::collections::HashMap;fn main() {// 创建商店库存let mut shop_inventory = HashMap::new();// 初始化商品shop_inventory.insert("生命药水", 5);   // 5瓶库存shop_inventory.insert("魔法卷轴", 3);   // 3个库存// 玩家购买行为let purchase = vec!["生命药水", "魔法卷轴", "未知药剂"];for item in purchase {// 使用entry API更新库存shop_inventory.entry(item).and_modify(|count| *count -= 1).or_insert(0); // 处理不存在的商品println!("{}库存更新:", item);println!("当前库存状态:{:#?}", shop_inventory);}// 每日补货shop_inventory.insert("生命药水", 10); // 直接覆盖补货println!("\n=== 补货后库存 ===");for (item, count) in &shop_inventory {println!("{}:{}件", item, count);}
}

魔法水晶球显示:

生命药水库存更新:
当前库存状态:{"生命药水": 4,"魔法卷轴": 3,
}
魔法卷轴库存更新:
当前库存状态:{"生命药水": 4,"魔法卷轴": 2,
}
未知药剂库存更新:
当前库存状态:{"生命药水": 4,"魔法卷轴": 2,"未知药剂": 0,
}=== 补货后库存 ===
生命药水:10件
魔法卷轴:2件
未知药剂:0件

魔法学院毕业手册

  1. 选择正确的钥匙 → 键类型需要实现EqHash特质
  2. 内存管理法则 → String作为键时会转移所有权
  3. 容量预言术 → 使用with_capacity预分配空间提升性能
  4. 防御性魔法 → 处理get返回的Option类型
  5. 时空旅行秘诀 → 遍历时借用避免所有权转移

记住:在Rust的魔法世界里,HashMap不是简单的储物袋,而是需要签订契约的次元空间。现在拿起你的法杖(键盘),去创造属于自己的哈希映射魔法吧!🎩✨

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/67955.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用 Elastic Cloud Hosted 优化长期数据保留:确保政府合规性和效率

作者&#xff1a;来自 Elastic Jennie Davidowitz 在数字时代&#xff0c;州和地方政府越来越多地承担着管理大量数据的任务&#xff0c;同时确保遵守严格的监管要求。这些法规可能因司法管辖区而异&#xff0c;通常要求将数据保留较长时间 —— 有时从一年到七年不等。遵守刑事…

Oracle Primavera P6 最新版 v24.12 更新 2/2

目录 一. 引言 二. P6 EPPM 更新内容 1. 用户管理改进 2. 更轻松地标准化用户设置 3. 摘要栏标签汇总数据字段 4. 将里程碑和剩余最早开始日期拖到甘特图上 5. 轻松访问审计数据 6. 粘贴数据时排除安全代码 7. 改进了状态更新卡片视图中的筛选功能 8. 直接从活动电子…

linux本地部署deepseek-R1模型

国产开源大模型追平甚至超越了CloseAI的o1模型&#xff0c;大国崛起时刻&#xff01;&#xff01;&#xff01; DeepSeek R1 本地部署指南   在人工智能技术飞速发展的今天&#xff0c;本地部署AI模型成为越来越多开发者和企业关注的焦点。本文将详细介绍如何在本地部署DeepS…

C基础寒假练习(2)

一、输出3-100以内的完美数&#xff0c;(完美数&#xff1a;因子和(因子不包含自身)数本身 #include <stdio.h>// 函数声明 int isPerfectNumber(int num);int main() {printf("3-100以内的完美数有:\n");for (int i 3; i < 100; i){if (isPerfectNumber…

有限元分析学习——Anasys Workbanch第一阶段笔记梳理

第一阶段笔记主要源自于哔哩哔哩《ANSYS-workbench 有限元分析应用基础教程》 张晔 主要内容导图&#xff1a; 笔记导航如下&#xff1a; Anasys Workbanch第一阶段笔记(1)基本信息与结果解读_有限元分析变形比例-CSDN博客 Anasys Workbanch第一阶段笔记(2)网格单元与应力奇…

html基本结构和常见元素

html5文档基本结构 <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><title>文档标题</title> </head> <body>文档正文部分 </body> </html> html文档可分为文档头和文档体…

Cursor如何使用Google Gemini以及碰到的坑

Cursor如何使用Google Gemini以及碰到的坑 Cursor介绍下载安装Google Gemini介绍Google Gemini 官网申请Google Gemini API网址 配置Cursor使用Google Gemini打开Corsur设置 Cursor介绍 ‌Cursor是一款基于人工智能的代码编辑器&#xff0c;旨在帮助开发者更高效地编写代码。‌…

【云安全】云原生-K8S-简介

K8S简介 Kubernetes&#xff08;简称K8S&#xff09;是一种开源的容器编排平台&#xff0c;用于管理容器化应用的部署、扩展和运维。它由Google于2014年开源并交给CNCF&#xff08;Cloud Native Computing Foundation&#xff09;维护。K8S通过提供自动化、灵活的功能&#xf…

【C++】线程池实现

目录 一、线程池简介线程池的核心组件实现步骤 二、C11实现线程池源码 三、线程池源码解析1. 成员变量2. 构造函数2.1 线程初始化2.2 工作线程逻辑 3. 任务提交(enqueue方法)3.1 方法签名3.2 任务封装3.3 任务入队 4. 析构函数4.1 停机控制 5. 关键技术点解析5.1 完美转发实现5…

【Linux系统】SIGCHLD 信号(选学了解)

SIGCHLD 信号 使用wait和waitpid函数可以有效地清理僵尸进程。父进程可以选择阻塞等待&#xff0c;直到子进程结束&#xff1b;或者采用非阻塞的方式&#xff0c;通过轮询检查是否有子进程需要被回收。 然而&#xff0c;无论是选择阻塞等待还是非阻塞的轮询方式&#xff0c;父…

【R语言】获取数据

R语言自带2种数据存储格式&#xff1a;*.RData和*.rds。 这两者的区别是&#xff1a;前者既可以存储数据&#xff0c;也可以存储当前工作空间中的所有变量&#xff0c;属于非标准化存储&#xff1b;后者仅用于存储单个R对象&#xff0c;且存储时可以创建标准化档案&#xff0c…

Vim的基础命令

移动光标 H(左) J(上) K(下) L(右) $ 表示移动到光标所在行的行尾&#xff0c; ^ 表示移动到光标所在行的行首的第一个非空白字符。 0 表示移动到光标所在行的行首。 W 光标向前跳转一个单词 w光标向前跳转一个单词 B光标向后跳转一个单词 b光标向后跳转一个单词 G 移动光标到…

Guided Decoding (借助FSM,有限状态自动机)

VLLM对结构化输出的支持&#xff1a; vllm/docs/source/features/structured_outputs.md at main vllm-project/vllm GitHub VLLM对tool call的支持&#xff1a; vllm/docs/source/features/tool_calling.md at main vllm-project/vllm GitHub 以上指定输出格式&#xf…

IFeatureWorkspace.CreateFeatureClass(),报错对COM组件的调用返回了错误 HRESULT E_FAIL

1、问题描述&#xff1a;在AE开发中&#xff0c;新增一个空的shpfile文件的时候&#xff0c;报错&#xff0c;如下图&#xff1a; 2、原因分析&#xff1a;产生此问题的原因是未设置默认字段的默认参数&#xff0c;特别是未设置IGeometryDef 参数。 3、解决方案&#xff1a;在…

算法题(48):反转链表

审题&#xff1a; 需要我们将链表反转并返回头结点地址 思路&#xff1a; 一般在面试中&#xff0c;涉及链表的题会主要考察链表的指向改变&#xff0c;所以一般不会允许我们改变节点val值。 这里是单向链表&#xff0c;如果要把指向反过来则需要同时知道前中后三个节点&#x…

Java 大视界 -- Java 大数据在智能医疗影像诊断中的应用(72)

💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也期待你毫无保留地分享独特见解,愿我们于此携手成长,共赴新程!💖 一、…

list容器(详解)

list的介绍及使用&#xff08;了解&#xff0c;后边细讲&#xff09; 1.1 list的介绍&#xff08;双向循环链表&#xff09; https://cplusplus.com/reference/list/list/?kwlist&#xff08;list文档介绍&#xff09; 1. list是可以在常数范围内在任意位置进行插入和删除的序…

MapReduce分区

目录 1. MapReduce分区1.1 哈希分区1.2 自定义分区 2. 成绩分组2.1 Map2.2 Partition2.3 Reduce 3. 代码和结果3.1 pom.xml中依赖配置3.2 工具类util3.3 GroupScores3.4 结果 参考 本文引用的Apache Hadoop源代码基于Apache许可证 2.0&#xff0c;详情请参阅 Apache许可证2.0。…

【C++STL标准模板库】二、STL三大组件

文章目录 1、容器2、算法3、迭代器 二、STL三大组件 1、容器 容器&#xff0c;置物之所也。 研究数据的特定排列方式&#xff0c;以利于搜索或排序或其他特殊目的&#xff0c;这一门学科我们称为数据结构。大学信息类相关专业里面&#xff0c;与编程最有直接关系的学科&…

算法题(57):找出字符串中第一个匹配项的下标

审题: 需要我们根据原串与模式串相比较并找到完全匹配时子串的第一个元素索引&#xff0c;若没有则返回-1 思路&#xff1a; 方法一&#xff1a;BF暴力算法 思路很简单&#xff0c;我们用p1表示原串的索引&#xff0c;p2表示模式串索引。遍历原串&#xff0c;每次遍历都匹配一次…