Rust 从模式中提取引用
示例
有时有必要仅使用引用就可以从对象中提取值(即,无需转让所有权)。
struct Token {
pub id: u32
}
struct User {
pub token: Option<Token>
}
fn main() {
//创建具有任意令牌的用户
let user = User { token: Some(Token { id: 3 }) };
//让我们通过引用来借用用户
let user_ref = &user;
// This match expression would not compile saying "cannot move out of borrowed
// content" because user_ref is a borrowed value but token expects an owned value.
match user_ref {
&User { token } => println!("User token exists? {}", token.is_some())
}
//通过在我们的模式中添加“ref”,我们指示编译器为我们提供参考
//而不是拥有的价值。
match user_ref {
&User { ref token } => println!("User token exists? {}", token.is_some())
}
//我们也可以将ref与销毁相结合
match user_ref {
//'ref'将允许我们通过引用访问期权内部的令牌
&User { token: Some(ref user_token) } => println!("Token value: {}", user_token.id ),
&User { token: None } => println!("There was no token assigned to the user" )
}
//引用也可以是可变的,让我们创建另一个用户来演示这一点
let mut other_user = User { token: Some(Token { id: 4 }) };
//给用户一个可变的参考
let other_user_ref_mut = &mut other_user;
match other_user_ref_mut {
//'refmut'为我们提供了可变的引用,使我们可以直接更改包含的值。
&mut User { token: Some(ref mut user_token) } => {
user_token.id = 5;
println!("New token value: {}", user_token.id )
},
&mut User { token: None } => println!("There was no token assigned to the user" )
}
}它将打印此:
User token exists? true Token value: 3 New token value: 5