尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

0282-KVS-使用 anyhow 处理错误

0282-KVS-使用 anyhow 处理错误
📅 发布时间:2026/6/20 16:47:04

环境

  • Time 2022-12-11
  • WSL-Ubuntu 22.04
  • Rust 1.65.0

前言

说明

参考:https://github.com/pingcap/talent-plan

目标

在上一节的基础上,新增 anyhow 依赖,处理代码中的错误。

Cargo.toml

[package]
edition = "2021"
name = "kvs"
version = "1.0.0"[dependencies]
anyhow = "1"
clap = {version = "4", features = ["derive"]}
serde = {version = "1", features = ["derive"]}
serde_json = "1"

main.rs

use clap::{Parser, Subcommand};
use kvs::KvStore;#[derive(Parser)]
#[command(author, version, about, long_about = None)]
struct Cli {#[command(subcommand)]command: Commands,
}#[derive(Subcommand)]
enum Commands {/// 设置值Set {/// 键key: String,/// 值value: String,},/// 获取值Get {/// 键key: String,},/// 删除值Rm {/// 键key: String,},
}fn main() -> anyhow::Result<()> {let cli = Cli::parse();let mut store = KvStore::new()?;match cli.command {Commands::Set { key, value } => {if let Some(value) = store.set(key.to_string(), value)? {println!("SET KEY: {key}, VALUE: {value}");} else {println!("SET KEY: {key}, VALUE: None");}}Commands::Get { key } => {if let Some(value) = store.get(&key)? {println!("GET KEY: {key}, VALUE: {value}");} else {println!("GET KEY: {key}, VALUE: None");}}Commands::Rm { key } => {if let Some(value) = store.remove(key.to_string())? {println!("REM KEY: {key}, VALUE: {value}");} else {println!("REM KEY: {key}, VALUE: None");}}}Ok(())
}

lib.rs

use anyhow::Result;
use log::CommandLog;mod cmd;
mod log;pub struct KvStore {log: CommandLog,
}impl KvStore {pub fn new() -> Result<KvStore> {Ok(Self {log: CommandLog::new()?,})}pub fn get(&mut self, key: &str) -> Result<Option<String>> {self.log.get(key)}pub fn set(&mut self, key: String, value: String) -> Result<Option<String>> {self.log.set(key, value)}pub fn remove(&mut self, key: String) -> Result<Option<String>> {self.log.remove(key)}
}

log.rs

use std::collections::HashMap;
use std::fs::{File, OpenOptions};
use std::io::{BufReader, BufWriter, Write};use anyhow::{Ok, Result};
use serde_json::Deserializer;use crate::cmd::Command;pub(crate) struct CommandLog {writer: BufWriter<File>,map: HashMap<String, String>,
}impl CommandLog {pub(crate) fn new() -> Result<Self> {let path = "/root/log/1.log";let writer = new_writer(path)?;let mut map = HashMap::default();load(path, &mut map)?;Ok(Self { writer, map })}pub(crate) fn get(&mut self, key: &str) -> Result<Option<String>> {Ok(self.map.get(key).map(String::from))}pub(crate) fn set(&mut self, key: String, value: String) -> Result<Option<String>> {let command = Command::Set { key, value };let json = serde_json::to_string(&command)?;self.writer.write_all(json.as_bytes())?;Ok(None)}pub(crate) fn remove(&mut self, key: String) -> Result<Option<String>> {let command = Command::Remove { key };let json = serde_json::to_string(&command)?;self.writer.write_all(json.as_bytes())?;Ok(None)}
}fn new_writer(path: &str) -> Result<BufWriter<File>> {let file = OpenOptions::new().append(true).create(true).open(path)?;Ok(BufWriter::new(file))
}fn load(path: &str, map: &mut HashMap<String, String>) -> Result<()> {let stream = Deserializer::from_reader(new_reader(path)?).into_iter();for cmd in stream {match cmd? {Command::Set { key, value } => map.insert(key, value),Command::Remove { key } => map.remove(&key),};}Ok(())
}fn new_reader(path: &str) -> Result<BufReader<File>> {let file = OpenOptions::new().read(true).open(path)?;Ok(BufReader::new(file))
}

总结

使用 anyhow 来处理程序中遇到的错误。

附录

相关新闻

  • 2025年口碑好的搜荐系统公司、2025年搜荐系统服务商、专业的搜荐系统平台、搜荐系统公司推荐、搜荐系统服务口碑推荐全面解析
  • Playwright for Python 的基本使用与常用交互API-使用笔记
  • 5款能帮你自动做PPT的AI工具,我全都试过了,最好用的是它!

最新新闻

  • 2026武汉市家里卫生间漏水、阳台漏水、楼顶漏水、阳台漏水、地下室渗水、阳光房漏水各种房屋漏水情况不用愁!本地防水补漏公司为您排忧解难!精准推荐附近专业防水团队 - 伶鹿到家
  • Fortinet高危SQL注入漏洞深度剖析:从原理到防御实战
  • 嵌入式开发实战:从技术文档到工业级系统构建全流程解析
  • 心电信号处理算法:从噪声滤波到精准诊断的工程实践
  • 卖家精灵AI全链路选品运营工具,2026卖家精灵优惠折扣码开通更新了 - 跨境电商卖家出海
  • AssetStudio终极指南:免费开源工具轻松提取Unity游戏资源

日新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

周新闻

  • Visual C++运行库修复终极指南:5分钟快速解决Windows软件启动错误
  • 手把手教你构建统计局地区经济数据爬虫:从环境搭建到数据持久化全指南
  • 2026多Agent深度解析:用AI团队替代单一模型,四种架构实战落地

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号