Rust

2025年07月12日更新 6 人订阅
原价: ¥ 6 限时优惠
专栏简介 Rust编程语言之错误处理 Rust 语言之 flod Rust编程语言之Cargo、Crates.io详解 Rust编程语言之枚举与模式匹配 Rust语言 - 接口设计的建议之受约束(Constrained) Rust编程语言之无畏并发 Rust语言 - 接口设计的建议之灵活(flexible) Rust语言 - 接口设计的建议之显而易见(Obvious) Rust语言 - 接口设计的建议之不意外(unsurprising) Rust 实战:构建实用的 CLI 工具 HTTPie Rust编程语言学习之高级特性 Rust内存管理揭秘:深度剖析指针与智能指针 解决Rust中数组和切片的编译时大小问题 《Rust编程之道》学习笔记一 Rust Async 异步编程 简易教程 使用 Async Rust 构建简单的 P2P 节点 Rust编程语言入门之模式匹配 Rust async 编程 Rust编程语言之编写自动化测试 Rust编程语言之函数式语言特性:迭代器和闭包 《Rust编程之道》学习笔记二 Rust Tips 比较数值 使用 Rust 开发一个微型游戏 Rust编程初探:深入理解Struct结构体 深入理解Rust中的内存管理:栈、堆与静态内存详解 深入理解 Rust 结构体:经典结构体、元组结构体和单元结构体的实现 深入掌握 Rust 结构体:从模板到实例化的完整指南 深入理解Rust中的结构体:逻辑与数据结合的实战示例 深入理解 Rust 枚举:从基础到实践 掌握Rust字符串的精髓:String与&str的最佳实践 全面解析 Rust 模块系统:实战案例与应用技巧 Rust 中的 HashMap 实战指南:理解与优化技巧 掌握Rust模式匹配:从基础语法到实际应用 Rust 中的面向对象编程:特性与实现指南 深入理解 Rust 的 Pin 和 Unpin:理论与实践解析 Rust Trait 与 Go Interface:从设计到实战的深度对比 从零开始:用 Rust 和 Axum 打造高效 Web 应用 Rust 错误处理详解:掌握 anyhow、thiserror 和 snafu Rust 如何优雅实现冒泡排序 链表倒数 K 节点怎么删?Python/Go/Rust 实战 用 Rust 玩转数据存储:JSON 文件持久化实战 Rust实战:打造高效字符串分割函数 如何高效学习一门技术:从知到行的飞轮效应 Rust 编程入门:Struct 让代码更优雅 Rust 编程:零基础入门高性能开发 用 Rust 写个猜数游戏,编程小白也能上手! Rust 入门教程:变量到数据类型,轻松掌握! 深入浅出 Rust:函数、控制流与所有权核心特性解析 从零开始:用 Rust 和 Axum 打造高效 Web 服务 Rust 集合类型解析:Vector、String、HashMap 深入浅出Rust:泛型、Trait与生命周期的硬核指南 Rust实战:博物馆门票限流系统设计与实现 用 Rust 打造高性能图片处理服务器:从零开始实现类似 Thumbor 的功能 Rust 编程入门实战:从零开始抓取网页并转换为 Markdown 深入浅出 Rust:高效处理二进制数据的 Bytes 与 BytesMut 实战 Rust智能指针:解锁内存管理的进阶之道 用 Rust 打造命令行利器:从零到一实现 mini-grep 解锁Rust代码组织:轻松掌握Package、Crate与Module Rust 所有权:从内存管理到生产力释放 深入解析 Rust 的面向对象编程:特性、实现与设计模式 Rust + Protobuf:从零打造高效键值存储项目 bacon 点燃 Rust:比 cargo-watch 更爽的开发体验 用 Rust 打造微型游戏:从零开始的 Flappy Dragon 开发之旅 函数式编程的Rust之旅:闭包与迭代器的深入解析与实践 探索Rust编程之道:从设计哲学到内存安全的学习笔记 精读《Rust编程之道》:吃透语言精要,彻底搞懂所有权与借用 Rust 避坑指南:搞定数值比较,别再让 0.1 + 0.2 != 0.3 困扰你! 告别 Vec!掌握 Rust bytes 库,解锁零拷贝的真正威力 告别竞态条件:基于 Axum 和 Serde 的 Rust 并发状态管理最佳实践 Rust 异步编程实践:从 Tokio 基础到阻塞任务处理模式 Rust 网络编程实战:用 Tokio 手写一个迷你 TCP 反向代理 (minginx) 保姆级教程:Zsh + Oh My Zsh 终极配置,让你的 Ubuntu 终端效率倍增 不止于后端:Rust 在 Web 开发中的崛起之路 (2024数据解读) Rust核心利器:枚举(Enum)与模式匹配(Match),告别空指针,写出优雅健壮的代码 Rust 错误处理终极指南:从 panic! 到 Result 的优雅之道

深入浅出 Rust:高效处理二进制数据的 Bytes 与 BytesMut 实战

深入浅出Rust:高效处理二进制数据的Bytes与BytesMut实战在高性能网络编程和二进制协议解析场景中,Rust的bytes库提供了强大的工具来高效管理二进制数据。本文通过一个简单的Rust示例,深入讲解Bytes和BytesMut类型的基本用法,帮助开发者快速上

深入浅出 Rust:高效处理二进制数据的 Bytes 与 BytesMut 实战

在高性能网络编程和二进制协议解析场景中,Rust 的 bytes 库提供了强大的工具来高效管理二进制数据。本文通过一个简单的 Rust 示例,深入讲解 Bytes 和 BytesMut 类型的基本用法,帮助开发者快速上手并理解其在实际项目中的应用价值。无论你是 Rust 新手还是有一定经验的开发者,这篇文章都将为你提供实用的代码分析与实践指导。

本文基于一个 Rust 示例代码,详细解析了 bytes 库中 Bytes 和 BytesMut 类型的使用方法。代码展示了如何创建、追加、分割、冻结和转换二进制缓冲区,并通过逐行分析和运行结果展示其功能。文章适合希望学习 Rust 高性能数据处理的开发者,涵盖了从安装依赖到实际运行的全流程,并提供相关参考资源。

实操

安装依赖

rust-ecosystem-learning on  main [!?] is 📦 0.1.0 via 🦀 1.87.0 
➜ cargo add bytes --dev

Bytes.rs 文件

use anyhow::Result;
use bytes::{BufMut, Bytes, BytesMut};

fn main() -> Result<()> {
    let mut buf = BytesMut::with_capacity(1024);
    buf.extend_from_slice(b"hello world\n");
    buf.put(&b"goodbye world"[..]);
    buf.put_u8(b'\n');
    buf.put_i64(1234567890);
    println!("buf: {:?}", buf);

    let buf1 = buf.split();
    println!("buf1: {:?}", buf1);
    let mut buf2 = buf1.freeze();
    println!("buf2: {:?}", buf2);

    let buf3 = buf2.split_to(12);
    println!("buf3: {:?}", buf3);
    println!("buf2: {:?}", buf2);

    let mut bytes = BytesMut::new();
    bytes.extend_from_slice(b"hello");

    println!("bytes: {:?}", bytes);

    let bytes = Bytes::from(b"hello".to_vec());
    assert_eq!(BytesMut::from(bytes), BytesMut::from(&b"hello"[..]));
    Ok(())
}

这段代码是一个 Rust 示例,演示了 bytes crate 的 Bytes 和 BytesMut 类型的基本用法,主要用于高效地处理二进制数据缓冲区。下面逐行解释:

use anyhow::Result;
use bytes::{BufMut, Bytes, BytesMut};
  • 引入 anyhow::Result 作为 main 的返回类型,方便错误处理。
  • 引入 bytes crate 的 BufMut trait 以及 Bytes、BytesMut 类型。

主函数

fn main() -> Result<()> {
  • main 函数返回 Result,便于用 ? 处理错误。

1. 创建和操作 BytesMut

    let mut buf = BytesMut::with_capacity(1024);
  • 创建一个可变的 BytesMut 缓冲区,初始容量为 1024 字节。
    buf.extend_from_slice(b"hello world\n");
  • 向缓冲区追加字节序列 "hello world\n"。
    buf.put(&b"goodbye world"[..]);
  • 使用 BufMut trait 的 put 方法追加 "goodbye world"。
    buf.put_u8(b'\n');
  • 追加一个字节(换行符)。
    buf.put_i64(1234567890);
  • 以大端序追加一个 64 位整数 1234567890。
    println!("buf: {:?}", buf);
  • 打印当前 buf 的内容(调试格式)。

2. split 和 freeze

    let buf1 = buf.split();
    println!("buf1: {:?}", buf1);
  • split 会将 buf 的内容全部“分离”出来,buf 变为空,buf1 拥有原内容。
    let mut buf2 = buf1.freeze();
    println!("buf2: {:?}", buf2);
  • freeze 会将 BytesMut 转换为不可变的 Bytes,buf2 现在是 Bytes 类型。

3. split_to

    let buf3 = buf2.split_to(12);
    println!("buf3: {:?}", buf3);
    println!("buf2: {:?}", buf2);
  • split_to(12) 会把 buf2 的前 12 个字节分离出来,buf3 拥有前 12 字节,buf2 剩下后面的内容。

4. BytesMut 新建与比较

    let mut bytes = BytesMut::new();
    bytes.extend_from_slice(b"hello");
    println!("bytes: {:?}", bytes);
  • 新建一个空的 BytesMut,追加 "hello",并打印。
    let bytes = Bytes::from(b"hello".to_vec());
    assert_eq!(BytesMut::from(bytes), BytesMut::from(&b"hello"[..]));
  • 创建一个 Bytes,内容为 "hello"。
  • 将 Bytes 转为 BytesMut,并与从字节切片 b"hello" 创建的 BytesMut 进行断言比较,确保内容一致。
    Ok(())
}
  • main 正常结束。

这段代码演示了 bytes crate 的 BytesMut(可变缓冲区)和 Bytes(不可变缓冲区)的常用操作,包括追加数据、分割、冻结、类型转换和内容比较。适合用于高性能网络编程、二进制协议解析等场景。

运行

rust-ecosystem-learning on  main [!?] is 📦 0.1.0 via 🦀 1.87.0 
➜ cargo run --example bytes
   Compiling rust-ecosystem-learning v0.1.0 (/Users/qiaopengjun/Code/Rust/rust-ecosystem-learning)
    Finished `dev` profile [unoptimized + debuginfo] target(s) in 0.42s
     Running `target/debug/examples/bytes`
buf: b"hello world\ngoodbye world\n\0\0\0\0I\x96\x02\xd2"
buf1: b"hello world\ngoodbye world\n\0\0\0\0I\x96\x02\xd2"
buf2: b"hello world\ngoodbye world\n\0\0\0\0I\x96\x02\xd2"
buf3: b"hello world\n"
buf2: b"goodbye world\n\0\0\0\0I\x96\x02\xd2"
bytes: b"hello"

总结

通过本文的示例代码,我们深入了解了 Rust bytes 库中 Bytes 和 BytesMut 类型的核心功能,包括缓冲区创建、数据追加、分割、冻结和类型转换等操作。这些功能在网络编程和二进制数据处理场景中尤为重要,展现了 Rust 在性能和内存安全上的优势。希望读者通过本文的讲解和实践,能够快速掌握 bytes 库的用法,并在实际项目中灵活运用。

参考

点赞 0
收藏 0
分享
本文参与登链社区写作激励计划 ,好文好收益,欢迎正在阅读的你也加入。

0 条评论

请先 登录 后评论