我有一个关于通过特征共享某些行为的值的模式匹配的问题。
我有一个带有两个变体的枚举,每个变体都有不同类型的绑定值,其中两种类型都实现一个特征。我试图弄清楚是否可以创建一个单一的模式(E::VarA(x) | E::VarB(x)
形式),其中我将两种类型绑定到一个常量,前提是我只对使用共享行为感兴趣。
一个说明性的例子::
trait T {
fn f(&self) -> usize;
}
struct A;
impl T for A {
fn f(&self) -> usize { 1 }
}
struct B;
impl T for B {
fn f(&self) -> usize { 2 }
}
enum E {
VarA(A),
VarB(B),
}
fn unwrap(e: E) -> usize {
match e {
E::VarA(v) | E::VarB(v) => T::f(&v)
}
}
fn main() {
let val = E::VarA(A{});
println!("{}", unwrap(val));
}
代码显然无法编译,但它显示了我的意图。有没有办法让代码工作,最好比简单地拆分更优雅pat1 | pat2 => ...
into pat1 => ... ; pat2 => ...
?
您可以创建一个宏来展开匹配语句。
trait T {
fn f(&self) -> usize;
}
struct A;
impl T for A {
fn f(&self) -> usize { 1 }
}
struct B;
impl T for B {
fn f(&self) -> usize { 2 }
}
enum E {
VarA(A),
VarB(B),
}
macro_rules! unwrap {
($value:expr, $pattern:pat => $result:expr) => {
match $value {
E::VarA($pattern) => $result,
E::VarB($pattern) => $result,
}
};
}
fn main() {
let a = E::VarA(A{});
let b = E::VarB(B{});
println!("a:{} b:{}",
unwrap!(a, ref sm => sm.f()),
unwrap!(b, ref sm => sm.f()));
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)