玩弄 Rust,我将一些代码提取到一个类中。为了保持它独立但独立的功能,我想保留一个回调函数并稍后调用它。为了保持简单,包括跳过明显的内容fn new()
,我们有这样的东西:
pub struct Toy {
go: fn(count: i16) -> String,
}
impl Toy {
fn lets_go(&mut self, n: i16) -> String {
self.go(n)
}
}
建筑给了我...
...path.../src/toy.rs:7:14: 7:19 error: type `&mut toy::Toy` does not implement any method in scope named `go`
...path.../src/toy.rs:7 self.go(n)
据推测,有一种特殊的语法(或完全不同的构造)可以理解self.go()
致电,但我在任何文档中都没有看到类似情况的示例或描述,因此我将不胜感激。
明显地,.go
could是一个类似函子的类,但这对于 Rust 来说似乎不太惯用。
foo.bar(...)
始终被解析为方法调用,它从不查找字段。这可以避免歧义,尤其是在特征方面。通过将调用和字段访问分成两个不同的表达式,可以强制其成为字段访问,例如,
let f = self.go;
f(n)
或者,更好,只是(self.go)(n)
.
Issue #2392涵盖改进这些诊断。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)