我试图了解如何为我自己的类型编写 atrait
和 an来处理一些输入数据。impl
我从一个简单的例子开始,我想1, 2, 3, 4
用trait Processor
. 一个实现将跳过第一个元素并将所有剩余的输入加倍。因此它应该看起来像这样:
trait Processor {} // TBD
struct SkipOneTimesTwo;
impl Processor for SkipOneTimesTwo {} // TBD
let numbers = vec![1, 2, 3, 4];
let it = numbers.iter();
let it = Box::new(it);
let proc = SkipOneTimesTwo;
let four_to_eight = proc.process(it);
assert_eq!(Some(4), four_to_eight.next());
assert_eq!(Some(6), four_to_eight.next());
assert_eq!(Some(8), four_to_eight.next());
assert_eq!(None, four_to_eight.next());
所以我的假设是我的特征和相应的实现看起来像这样:
trait Processor {
// Arbitrarily convert from `i32` to `u32`
fn process(&self, it: Box<dyn Iterator<Item = i32>>) -> Box<dyn Iterator<Item = u32>>;
}
struct SkipOneTimesTwo;
impl Processor for SkipOneTimesTwo {
fn process(&self, it: Box<dyn Iterator<Item = i32>>) -> Box<dyn Iterator<Item = u32>> {
let p = it.skip(1).map(|i| 2 * (i as u32));
Box::new(p)
}
}
此代码不能按原样工作。我收到以下错误:
7 | let four_to_eight = proc.process(it);
| ^^ expected `i32`, found reference
|
= note: expected type `i32`
found reference `&{integer}`
= note: required for the cast to the object type `dyn Iterator<Item = i32>`
如果我的输入数据非常大,我不希望将整个数据集保存在内存中(使用的全部要点Iterator
),所以我假设 usingIterator<T>
应该从原始输入源流式传输数据,直到最终聚合或以其他方式处理。但是,就我需要在这里注释的生命周期而言,我不知道这意味着什么。
最终,我Processor
可能会保存来自输入的一些中间数据(例如,用于运行平均计算),因此我可能必须在我的结构上指定生命周期。
处理一些编译器错误时,我尝试将'a
、'static
和'_
生命周期添加到 my dyn Iterator<...>
,但我不太清楚如何传递输入迭代器并懒惰地修改值。
这甚至是一个合理的方法吗?我可能可以将输入存储Iterator<Item = i32>
在我的 struct andimpl Iterator<Item = u32> for SkipOneTimesTwo
中,但是我大概会失去一些能够传递Processor
特征的抽象。