如何扩展在另一个板条箱中定义的特征?
我想创建一种新的迭代方法,例如:
let test_data = vec![1,2,3,1,1,1,1];
let indexes_with_val_1 = test_data.iter().find_all(|element| element == 1).unwrap();
assert_eq!(indexes_with_val_1, vec!(0,3,4,5,6));
因此,从本质上讲,我想在 std :: iter :: iterator :: iterator
特征上添加一个新方法,但找不到适用于此的
示例这不是问题,因为我的功能可以正常工作,所以我只想能够像代码示例那样使用它以获得更好的人体工程学。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
您可以使用称为迭代特征,但是您可以编写一个新的特征。这就是我们要做的。
iteratorext
,其中包含您的自定义方法。Iterator
的类型编写一个blanketimpl
Inlph 。iteratorext
以访问您的扩展功能。例如,我们可以在迭代器中添加一个名为
my_extension
的简单函数,因此唯一的缺点是您必须导入新特征才能使用它。因此,如果您想在另一个文件中使用
my_extension
,则必须专门导入iteratorext
才能这样做。以我的经验,生锈社区在某种程度上有所分歧,这是合法的练习还是要避免的攻击,因此您的里程可能会有所不同。
You can use a design pattern called extension traits. You can't extend the
Iterator
trait, but you can write a new one. Here's what we're going to do.IteratorExt
, which has your custom method in it.impl
that implementsIteratorExt
for any type that implementsIterator
.IteratorExt
to get access to your extension function.For example, we can add a simple function called
my_extension
to iterators like soThe only downside is that you have to import the new trait to use it. So if you want to use
my_extension
in another file, you have to importIteratorExt
specifically in order to do so.In my experience, the Rust community is somewhat divided on whether this is legitimate practice or whether it's a hack to be avoided, so your mileage may vary.
存在扩展特质模式为此。
这个想法是您创建一个特征,通常由惯例命名为
traitext
,并为所有实现特质
:There exist the extension trait pattern for that.
The idea is that you create a trait, usually named
TraitExt
by convention, and implement it for all implementations ofTrait
: