如何使用特征的不同实现实例化相同的结构?

时间:2021-01-05 21:59:06

标签: struct rust traits

我有一个 trait,它由同一个结构以不同的方式实现。为了实现这一点,我有不同的结构,它们具有不同的实现。对于抽象,我将把这些结构称为 A-Z:

trait Trait {
    fn bar<T: Trait> (&self, z: &Struct3<T>) -> Struct3<T>;
}
struct StructA {
    name: String,
    color: String,
}
impl Trait for StructA {
    fn bar<T: Trait> (&self, z: &Struct3<T>) -> Struct3<T>{

        let mut list = Vec::new();
        list.push(self.clone());

        let y = Struct2::<T> {
            name: z.y.name,
            list: list,
        };

        Struct3::<T> {
            point: 1,
            y: y,
        }
    }
}
struct StructZ {
    name: String,
    color: String,
}
impl Trait for StructZ {
    fn bar<T: Trait> (&self, z: &Struct3<T>) -> Struct3<T>{

        let mut list = Vec::new();
        list.push(self.clone());

        let y = Struct2::<T> {
            name: z.y.name,
            list: list,
        };

        Struct3::<T> {
            point: 26,
            y: y,
        }
    }
}

是否有另一种方法来解决这个问题,以便结构的每个实例都有不同的特征实现,或者创建一个新的结构是最好的方法?

我是编译语言的新手。我所做的大部分工作都是使用 Python 和 TypeScript。

1 个答案:

答案 0 :(得分:4)

做到这一点的一种方法是使您的 trait 对某些类型具有泛型(即使该类型实际上并未在 trait 内使用)。

trait Trait<T> { /* ... */ }

这使您可以为同一个结构多次实现它。

impl Trait<bool> for Struct { /* ... */ }
impl Trait<u32> for Struct { /* ... */ }

这里,boolu32 只是成为编译时标志来选择您要使用的 Trait 的实现。

let struct_3a = Trait::<bool>::bar(&my_object, /* ... */);
let struct_3b = Trait::<u32>::bar(&my_object, /* ... */);

我在这里使用了 boolu32,但您可以在这里使用自己的类型以使一切更清晰。

相关问题