首页 > 解决方案 > 将借用值的向量收集到借用特征的向量中

问题描述

Vec<&dyn Trait>是否可以从实现的值的迭代器中收集 a Trait

这是一个示例,基于属于特征问题的对象的向量:

trait Animal {
    fn make_sound(&self) -> String;
}

struct Dog;
impl Animal for Dog {
    fn make_sound(&self) -> String {
        "woof".to_string()
    }
}

fn main() {
    let dogs = [Dog, Dog];
    let v: Vec<&dyn Animal> = dogs.iter().collect();

    for animal in v.iter() {
        println!("{}", animal.make_sound());
    }
}

这失败了error[E0277]: a value of type "Vec<&dyn Animal>" cannot be built from an iterator over elements of type &Dog`

但是,如果您使用将狗单独推入 vec(如原始问题的答案),则它可以正常工作。

let dog1: Dog = Dog;
let dog2: Dog = Dog;

let v: Vec<&dyn Animal> = Vec::new();
v.push(&dog1);
v.push(&dog2);

标签: rustpolymorphismidioms

解决方案


为了将结构的迭代器收集到由结构实现的特征的向量中,可以使用map迭代器的方法将借来的结构转换为借来的特征。

let dogs = [Dog, Dog];
let v: Vec<&dyn Animal> = dogs.iter().map(|a| a as &dyn Animal ).collect();

有关更多信息,请参阅此游乐场


推荐阅读