用Rust实现23种设计模式之抽象工厂

在 Rust 中,可以使用 trait 和泛型来实现抽象工厂模式。抽象工厂模式是一种创建型设计模式,它提供了一个接口来创建一系列相关或依赖对象的家族,而无需指定具体的类。下面是一个简单的示例,展示了如何使用 Rust 实现抽象工厂模式:

bash 复制代码
// 定义抽象产品族
trait AbstractProductA {
    fn operation_a(&self);
}
 trait AbstractProductB {
    fn operation_b(&self);
}
 // 实现具体产品族1
struct ConcreteProductA1;
impl AbstractProductA for ConcreteProductA1 {
    fn operation_a(&self) {
        println!("ConcreteProductA1 operation");
    }
}
 struct ConcreteProductB1;
impl AbstractProductB for ConcreteProductB1 {
    fn operation_b(&self) {
        println!("ConcreteProductB1 operation");
    }
}
 // 实现具体产品族2
struct ConcreteProductA2;
impl AbstractProductA for ConcreteProductA2 {
    fn operation_a(&self) {
        println!("ConcreteProductA2 operation");
    }
}
 struct ConcreteProductB2;
impl AbstractProductB for ConcreteProductB2 {
    fn operation_b(&self) {
        println!("ConcreteProductB2 operation");
    }
}
 // 定义抽象工厂
trait AbstractFactory {
    fn create_product_a(&self) -> Box<dyn AbstractProductA>;
    fn create_product_b(&self) -> Box<dyn AbstractProductB>;
}
 // 实现具体工厂1
struct ConcreteFactory1;
impl AbstractFactory for ConcreteFactory1 {
    fn create_product_a(&self) -> Box<dyn AbstractProductA> {
        Box::new(ConcreteProductA1)
    }
    fn create_product_b(&self) -> Box<dyn AbstractProductB> {
        Box::new(ConcreteProductB1)
    }
}
 // 实现具体工厂2
struct ConcreteFactory2;
impl AbstractFactory for ConcreteFactory2 {
    fn create_product_a(&self) -> Box<dyn AbstractProductA> {
        Box::new(ConcreteProductA2)
    }
    fn create_product_b(&self) -> Box<dyn AbstractProductB> {
        Box::new(ConcreteProductB2)
    }
}
 fn main() {
    // 使用具体工厂1创建具体产品族
    let factory1: Box<dyn AbstractFactory> = Box::new(ConcreteFactory1);
    let product_a1 = factory1.create_product_a();
    let product_b1 = factory1.create_product_b();
    product_a1.operation_a();
    product_b1.operation_b();
     // 使用具体工厂2创建具体产品族
    let factory2: Box<dyn AbstractFactory> = Box::new(ConcreteFactory2);
    let product_a2 = factory2.create_product_a();
    let product_b2 = factory2.create_product_b();
    product_a2.operation_a();
    product_b2.operation_b();
}

在上述示例中,我们首先定义了抽象产品族的 trait AbstractProductA 和 AbstractProductB ,分别定义了产品族中的操作方法。然后,我们实现了具体产品族1和具体产品族2,它们分别实现了 AbstractProductA 和 AbstractProductB trait。

接下来,我们定义了抽象工厂的 trait AbstractFactory ,其中定义了创建产品族中产品的方法。然后,我们实现了具体工厂1和具体工厂2,它们分别实现了 AbstractFactory trait,并实现了创建具体产品族的方法。

在 main 函数中,我们使用具体工厂创建具体产品族,并调用产品的操作方法。

通过抽象工厂模式,我们可以在运行时动态选择具体工厂和产品族,实现了创建对象的解耦和灵活性。

相关推荐
Cloud_Shy61812 分钟前
解读《Effective Python 3rd Edition》:从练气到老魔(第五章 Item 30 - 32)
开发语言·人工智能·笔记·python·学习方法
天佑木枫38 分钟前
15天Python入门系列 · 序
开发语言·python
宋拾壹2 小时前
同时添加多个类目
android·开发语言·javascript
凡人叶枫2 小时前
Effective C++ 条款04:确定对象被使用前已先被初始化
java·linux·开发语言·c++·嵌入式开发
小小龙学IT2 小时前
Go 语言后端开发:从并发模型到生产落地的工程实践
开发语言·后端·golang
ytttr8733 小时前
Qt 数字键盘实现
开发语言·qt
wearegogog1233 小时前
C# .NET 文件比较工具 WinForms
开发语言·c#·.net
再写一行代码就下班3 小时前
Cursor配置Java环境、创建Spring Boot项目的步骤
java·开发语言·spring boot
零陵上将军_xdr3 小时前
后端转全栈学习-Day5-JavaScript 基础-3
开发语言·javascript·学习
oqX0Cazj23 小时前
2026超火Go-Zero实战:从架构原理到高并发接口落地,彻底解决接口超时、雪崩问题
开发语言·架构·golang