Rust clousure
发表于|更新于|clousure
|浏览量:
错误传播运算符?
let socket = UdpSocket::bind(bind_addr).map_err(MSG::Io)?; |
如果表达式(如 UdpSocket::bind(bind_addr).map_err(MSG::Io))返回 Ok(val),就把 val 取出来继续执行后面的代码。
如果返回 Err(e),就立刻把 Err(e) 返回,终止当前函数,不再往下执行。
如果 bind 成功,socket 就是绑定好的 UdpSocket。
如果 bind 失败,错误会被 map_err(MSG::Io) 转换成 MSG::Io,然后 ? 直接把 Err(MSG::Io(…)) 返回给调用者。
文章作者: 索雷博
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来源 雷子集中营!
相关推荐

2026-05-28
Rust Testing
Testing Patterns and Strategies 测试类型 描述 示例 #[should_panic] 测试预期失败,验证代码在特定条件下会触发 panic。 #[should_panic(expected = "index out of bounds")] #[ignore] 标记缓慢或依赖硬件的测试,默认跳过,需手动运行。 #[ignore = "requires GPU hardware"] 返回 Result 的测试 使用 Result 替代 unwrap,更清晰地处理错误。 fn test_config_parsing() -> Result<(), Box<dyn std::error::Error>> { ... } 测试夹具 (Fixtures) 使用构建器模式和 Drop 自动清理测试资源。 struct TestFixture { temp_dir: PathBuf, ... } 模拟特征 (Mocking...

2026-05-28
Rust async
async/awaitRust 的 async/await 是一种协作式(Cooperative)异步编程模型。它允许你在等待 I/O 操作(如网络请求、数据库查询)时,挂起当前任务并释放 CPU,去处理其他任务,从而实现高并发。 Featureasync 函数不会立即执行,而是返回一个实现了 Future trait 的对象 懒惰性(Lazy):Future 本质上是一个状态机(State Machine)。当调用一个 async 函数时,它只会创建一个结构体,记录需要做什么,但不会执行任何代码。 驱动(Polling):只有当通过 .await 显式调用它,或者交给一个异步运行时(如 Tokio)去 poll(轮询)时,这个任务才开始真正向前推进。 async & await async fn:定义一个异步函数。它会将函数体编译为一个包含所有局部变量的状态机 .await:告诉运行时:“我在这里暂停,直到这个任务完成。如果没完成,请先去运行别的任务” 协作式调度Rust 的异步模型有一个显著特点:Rust...

2026-05-28
Rust
代码注释// 行注释/* 块注释*/ 文档注释 文档注释需要位于 lib 类型的包中,例如 src/lib.rs 中 文档注释可以使用 markdown语法!例如 # Examples 的标题,以及代码块高亮 被注释的对象需要使用 pub 对外可见,记住:文档注释是给用户看的,内部实现细节不应该被暴露出去 /// 文档注释/// `add_one` 将指定值加1////// # Examples////// ```/// let arg = 5;/// let answer = my_crate::add_one(arg);////// assert_eq!(6, answer);/// ```pub fn add_one(x: i32) -> i32 { x + 1} 文档块注释 /** `add_two` 将指定值加2# Examples let arg = 5;let answer = my_crate::add_two(arg); assert_eq!(7, answer); */pub fn...

2026-05-28
Rust generics
Implementation实现 impl const 泛型fn display_array<T: std::fmt::Debug, const N: usize>(arr: [T; N]) { println!("{:?}", arr);}fn main() { let arr: [i32; 3] = [1, 2, 3]; display_array(arr); let arr: [i32; 2] = [1, 2]; display_array(arr);} 假设某段代码需要在内存很小的平台上工作,因此需要限制函数参数占用的内存大小,此时就可以使用 const 泛型表达式来实现: // 目前只能在nightly版本下使用#![allow(incomplete_features)]#![feature(generic_const_exprs)]fn something<T>(val: T)where Assert<{...

2026-05-28
Rust smart point
声明式宏 macro_rules!模式解析简化的vec! #[macro_export] // 宏导出macro_rules! vec { // 宏定义 ( $( $x:expr ),* ) => { // 模式匹配 { let mut temp_vec = Vec::new(); $( temp_vec.push($x); )* temp_vec } };} ( $( $x:expr ),* )的含义圆括号 () 将整个宏模式包裹其中。紧随其后的是 $(),跟括号中模式相匹配的值(传入的 Rust 源代码)会被捕获,然后用于代码替换。在这里,模式 $x:expr 会匹配任何 Rust 表达式并给予该模式一个名称:$x $() 之后的逗号说明 $() 所匹配的代码使用逗号分隔符分割,紧随逗号之后的 * 说明 *...

2026-05-28
Rust
typeOptionOption: 枚举类型,处理缺失值的核心, 取代 null // Option 定义enum Option<T> { Some(T), // 盒子装了一个类型为 T 的值 None, // 盒子是空的} Some(T):代表“有值”。T 是具体的数据类型(比如 i32、String 等)None:代表“没值”。它是专门用来表示“什么都没有”的占位符 生命周期静态生命周期 'static#![allow(unused)]fn main() {// String literals are always 'static — they live in the binary's read-only sectionlet s: &'static str = "hello"; // Same as: static const char* s = "hello"; in C// Constants are also...
