generics-traits/trait-object #220
Replies: 32 comments 28 replies
-
fn hatch_a_bird(num: u8) -> Box<dyn Bird>{
match num {
1 => Box::new(Swan),
_ => Box::new(Duck),
}
} |
Beta Was this translation helpful? Give feedback.
-
let birds:[Box<dyn Bird>; 2] = [Box::new(Duck), Box::new(Swan)]; |
Beta Was this translation helpful? Give feedback.
-
// 通过泛型实现以下函数
fn static_dispatch<T>(param: T)
where T:Foo
{
println!("{}", param.method());
}
// 通过特征对象实现以下函数
fn dynamic_dispatch(param:&dyn Foo){
println!("{}", param.method());
} |
Beta Was this translation helpful? Give feedback.
-
第四题也可以通过 impl 语法实现,不过不知道是不是合乎规矩的 fn static_dispatch(foo: impl Foo) {
foo.method();
} |
Beta Was this translation helpful? Give feedback.
-
done,本节主要讲了特征对象的相关知识,其中使用到了dyn关键字,这个dyn关键字我觉得和rust最初的设计理念并不相符,因为rust本身是想要在编译阶段就确定所有参数的类型的,这样程序的运行时性能才会最高,dyn动态分发就破坏了这一理念,拙见,轻喷 |
Beta Was this translation helpful? Give feedback.
-
done!这里的第六题有一个新的思路,使用 泛型特征(Generic Traits) ,代码如下: trait MyTrait<T> {
fn f(&self) -> T;
}
impl MyTrait<u32> for u32 {
fn f(&self) -> u32 { 42 }
}
impl MyTrait<String> for String {
fn f(&self) -> String { self.clone() }
}
fn my_function<T: MyTrait<T>> (x: Box<dyn MyTrait<T>>) -> T { // could be discarded
x.f()
}
fn my_function_2<T: MyTrait<T>> (x: Box<T>) -> T { // could be discarded
x.f()
}
fn main() {
my_function(
Box::new(13_u32)
);
my_function(
Box::new( String::from("abc") )
);
my_function_2(
Box::new(13_u32)
);
my_function_2(
Box::new( String::from("abc") )
);
println!("Success!")
} |
Beta Was this translation helpful? Give feedback.
-
再更新一个6的思路 trait MyTrait {
type Output;
fn f(&self) -> Self::Output;
}
impl MyTrait for u32 {
type Output = u32;
fn f(&self) -> Self::Output { 42 }
}
impl MyTrait for String {
type Output = String;
fn f(&self) -> Self::Output { self.clone() }
}
fn my_function<T: MyTrait<Output = T>> (
x: Box<dyn MyTrait<Output = T>>
) -> T { // could be discarded
x.f()
}
fn my_function_2<T: MyTrait<Output = T>> (
x: Box<T>
) -> T { // could be discarded
x.f()
}
fn main() {
my_function(
Box::new(13_u32)
);
my_function(
Box::new( String::from("abc") )
);
my_function_2(
Box::new(13_u32)
);
my_function_2(
Box::new( String::from("abc") )
);
println!("Success!")
} |
Beta Was this translation helpful? Give feedback.
-
来个花活,虽然编译过去了,但是应该属于静态的 // 通过特征对象实现以下函数, |
Beta Was this translation helpful? Give feedback.
-
第二题可以根据特征对象的学习内容 写成 let birds : Vec<Box> = vec![Box::new(Duck{}),Box::new(Swan{})];; |
Beta Was this translation helpful? Give feedback.
-
trait MyTrait {
fn f(&self) -> Self;
}
impl MyTrait for u32 {
fn f(&self) -> u32 { 42 }
}
impl MyTrait for String {
fn f(&self) -> String { self.clone() }
}
fn my_function(x: impl MyTrait) -> impl MyTrait {
x.f()
}
fn main() {
my_function(13_u32);
my_function(String::from("abc"));
} 第五题的这个为什么可以通过啊,my_function()不是返回了两种不同的类型(u32和String)吗 |
Beta Was this translation helpful? Give feedback.
-
10.4特征对象第5题,我有一种邪道做法hhh,把函数都设置为不返回值 // 使用至少两种方法让代码工作
// 不要添加/删除任何代码行
trait MyTrait {
fn f(&self);
}
impl MyTrait for u32 {
fn f(&self){ 42 ;}
}
impl MyTrait for String {
fn f(&self) { self.clone() ;}
}
fn my_function(x: Box<dyn MyTrait>) {
x.f();
}
fn main() {
my_function(Box::new(13_u32));
my_function(Box::new(String::from("abc")));
println!("Success!")
} |
Beta Was this translation helpful? Give feedback.
-
第二题 三种方式: let birds:Vec<&dyn Bird> = vec![&Duck, &Swan] let birds:Vec<Box<dyn Bird>>=vec![Box::new(Duck),Box::new(Swan)] let birds:[Box<dyn Bird>;2] = [Box::new(Duck), Box::new(Swan)] |
Beta Was this translation helpful? Give feedback.
-
第5题
trait MyTrait<T> {
fn f(&self) -> T;
}
impl MyTrait<u32> for u32 {
fn f(&self) -> u32 { 42 }
}
impl MyTrait<String> for String {
fn f(&self) -> String { self.clone() }
}
fn my_function<T>(x: Box<dyn MyTrait<T>>) -> T {
x.f()
}
fn main() {
my_function(Box::new(13_u32));
my_function(Box::new(String::from("abc")));
println!("Success!")
}
trait MyTrait {
fn f(&self) -> Self;
}
impl MyTrait for u32 {
fn f(&self) -> Self { 42 }
}
impl MyTrait for String {
fn f(&self) -> Self { self.clone() }
}
fn my_function(x: impl MyTrait) -> impl MyTrait {
x.f()
}
fn main() {
my_function(13_u32);
my_function(String::from("abc"));
println!("Success!")
} |
Beta Was this translation helpful? Give feedback.
-
第五题的官方题解:
|
Beta Was this translation helpful? Give feedback.
-
没太懂 为什么第二题这样写就不行
|
Beta Was this translation helpful? Give feedback.
-
Done。最后一题,如果只考虑我们目前已经学过的方法,那么就是
题解将 dyn 变成泛型。虽然违反了第二条规定,但是我们只要避免使用 dyn 即可——将所有函数都改成泛型实现。 trait MyTrait {
fn f(&self) -> Self;
}
impl MyTrait for u32 {
fn f(&self) -> Self { 42 }
}
impl MyTrait for String {
fn f(&self) -> Self { self.clone() }
}
fn my_function (x: impl MyTrait ) -> impl MyTrait {
x.f()
}
fn main() {
my_function(13_u32);
my_function(String::from("abc"));
println!("Success!")
} 返回 Box 而不是 Self从而避免违反第一条规定。 trait MyTrait {
fn f(&self) -> Box<dyn MyTrait>;
}
impl MyTrait for u32 {
fn f(&self) -> Box<dyn MyTrait> { Box::new(42) }
}
impl MyTrait for String {
fn f(&self) -> Box<dyn MyTrait> { Box::new(self.clone()) }
}
fn my_function (x: &dyn MyTrait ) -> Box<dyn MyTrait> {
x.f()
}
fn main() {
my_function(&13_u32);
my_function(&String::from("abc"));
println!("Success!")
} |
Beta Was this translation helpful? Give feedback.
-
帮忙解答下这里是什么错误? &self.clone() 的类型和 self 的类型都是 &String,为什么clone的string取引用会报错? // 使用至少两种方法让代码工作
// 不要添加/删除任何代码行
trait MyTrait {
fn f(&self) -> &dyn MyTrait;
}
impl MyTrait for u32 {
fn f(&self) -> &dyn MyTrait { &42 }
}
impl MyTrait for String {
fn f(&self) -> &dyn MyTrait {
// &self.clone() // 这里会失败 returns a value referencing data owned by the current function
self // 这里却可以
}
}
fn my_function(x: &dyn MyTrait) -> &dyn MyTrait {
x.f()
}
fn main() {
my_function(&13_u32);
my_function(&String::from("abc"));
println!("Success!")
} |
Beta Was this translation helpful? Give feedback.
-
fn hatch_a_bird<'a>(select: i32) -> &'a dyn Bird { |
Beta Was this translation helpful? Give feedback.
-
mark finished |
Beta Was this translation helpful? Give feedback.
-
// 使用至少两种方法让代码工作 impl MyTrait for u32 { impl MyTrait for String { fn my_function(x: Box) { fn main() {
} |
Beta Was this translation helpful? Give feedback.
-
Day 9 |
Beta Was this translation helpful? Give feedback.
-
最后一题我的思路: // 使用至少两种方法让代码工作
// 不要添加/删除任何代码行
trait MyTrait {
fn f(&self) -> Box<dyn MyTrait>;
}
impl MyTrait for u32 {
fn f(&self) -> Box<dyn MyTrait> {
Box::new(42)
}
}
impl MyTrait for String {
fn f(&self) -> Box<dyn MyTrait> {
Box::new(self.clone())
}
}
fn my_function(x: Box<dyn MyTrait>) -> Box<dyn MyTrait> {
x.f()
}
fn main() {
my_function(Box::new(13_u32));
my_function(Box::new(String::from("abc")));
println!("Success!")
} // 使用至少两种方法让代码工作
// 不要添加/删除任何代码行
trait MyTrait {
fn f(&self) -> Self;
}
impl MyTrait for u32 {
fn f(&self) -> Self { 42 }
}
impl MyTrait for String {
fn f(&self) -> Self { self.clone() }
}
fn my_function<T: MyTrait>(x: Box<T>) -> T {
x.f()
}
fn main() {
my_function(Box::new(13_u32));
my_function(Box::new(String::from("abc")));
println!("Success!")
} |
Beta Was this translation helpful? Give feedback.
-
generics-traits/trait-object
Learn Rust with Example, Exercise and real Practice, written with ❤️ by https://course.rs team
https://practice.rs/generics-traits/trait-object.html
Beta Was this translation helpful? Give feedback.
All reactions