rust 的这段代码看不懂,求指教!

2021-06-29 14:57:03 +08:00
 hahaFck
rust 的范型太复杂了。

1.声明了一个范型结构体:

struct Complex<T> {
re: T,
im: T
}

2.为结构体实现+操作符操作,即实现 Add trait

impl<T: Add<T, Output=T>> Add for Complex<T> {
type Output = Complex<T>;
fn add(self, rhs: Complex<T>) -> Self::Output {
Complex { re: self.re + rhs.re, im: self.im + rhs.im }
}
}

3.问题就出现在这个 T: Add<T, Output=T>,系统的 Add 的定义为 pub trait Add<Rhs = Self> {...}
明明范型参数只有一个 Rhs,并且默认值是 Self,为什么那段代码可以写成 Add<T, Output=T>,这里明明有 2 个范型参数呢,一个 T,一个 Output,有点看不明白。
2409 次点击
所在节点    Rust
3 条回复
codehz
2021-06-29 15:06:27 +08:00
Output 是 associted type,而不是泛型本身的参数
换句话说,Add 只要确定了第一个 T 就能唯一确定实现了,这里的 Output = T 写法实际上是简写,完整展开可以写成这样
impl <T> Add for Complex<T> where
T: Add<T>,
<T as Add<T>>::Output: T,
也就是说后面的 Output 实际上是针对 T as Add<T> 的额外约束,以确保不会意外匹配到 Output 不是 T 的类型
参考:
https://doc.rust-lang.org/rust-by-example/generics/assoc_items/types.html
https://stackoverflow.com/questions/32059370/when-is-it-appropriate-to-use-an-associated-type-versus-a-generic-type
https://blog.thomasheartman.com/posts/on-generics-and-associated-types
hahaFck
2021-06-29 15:23:43 +08:00
@codehz 多谢大神指点,我在看看资料,另外还有一个问题,就是 add 方法 fn add(self, rhs: Complex<T>) -> Self::Output

第一个参数是 self,而不是&self,那是不是调用了比如 a + b 后,是不是 a 就失去了所有权,但代码测试还是能访问 a 和 b 的。
xiaopanzi
2021-10-18 10:43:31 +08:00
@hahaFck 肯定就失去所有权啊。贴一下测试代码看看。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/786476

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX