23种设计模式之《工厂方法模式(Factory Method)》在c#中的应用及理解

工厂方法模式是一种创建型设计模式,它定义了一个用于创建对象的接口,但将具体的对象创建延迟到子类中。换句话说,工厂方法模式让子类决定实例化哪个类。

核心思想
  1. 抽象工厂接口

    定义一个接口(或抽象类),其中包含一个创建对象的方法(例如 CreateProduct)。这个方法的具体实现由子类完成。

  2. 具体工厂类

    每个具体工厂类负责创建一种具体的产品。例如,FactoryA 创建 ProductAFactoryB 创建 ProductB

  3. 产品接口

    定义一个产品接口,所有具体产品都需要实现这个接口。客户端代码通过产品接口与具体产品交互,而不需要知道具体产品的类名。

  4. 解耦

    客户端代码只需要知道工厂接口和产品接口,而不需要关心具体的产品类和工厂类。这样可以将对象的创建与使用分离,提高代码的灵活性和可维护性。

适用场景
  • 当系统需要支持多种产品类型,并且未来可能会增加新的产品类型时。

  • 当对象的创建过程复杂或需要解耦时。

  • 当客户端代码需要根据条件创建不同的对象时。

优点
  • 符合开闭原则,易于扩展。

  • 客户端代码与具体产品解耦,提高了代码的灵活性。

缺点
  • 每增加一个产品,就需要增加一个具体工厂类,可能会导致类的数量增加。

工厂方法模式的C#代码示例

下面是一个使用C#实现的工厂方法模式示例代码,并附有详细的文字说明。

代码实现

csharp

cs 复制代码
using System;

// 产品接口
public interface IProduct
{
    void Operation();
}

// 具体产品A
public class ProductA : IProduct
{
    public void Operation()
    {
        Console.WriteLine("ProductA operation.");
    }
}

// 具体产品B
public class ProductB : IProduct
{
    public void Operation()
    {
        Console.WriteLine("ProductB operation.");
    }
}

// 工厂接口
public interface IFactory
{
    IProduct CreateProduct();
}

// 具体工厂A,用于创建ProductA
public class FactoryA : IFactory
{
    public IProduct CreateProduct()
    {
        return new ProductA();
    }
}

// 具体工厂B,用于创建ProductB
public class FactoryB : IFactory
{
    public IProduct CreateProduct()
    {
        return new ProductB();
    }
}

class Program
{
    static void Main(string[] args)
    {
        // 创建工厂A并生产产品A
        IFactory factoryA = new FactoryA();
        IProduct productA = factoryA.CreateProduct();
        productA.Operation();

        // 创建工厂B并生产产品B
        IFactory factoryB = new FactoryB();
        IProduct productB = factoryB.CreateProduct();
        productB.Operation();
    }
}

代码说明

  1. 产品接口 IProduct

    • 定义了一个 Operation 方法,所有具体产品都需要实现这个接口。

    • 这是工厂方法模式的核心,确保所有产品具有统一的接口。

  2. 具体产品 ProductAProductB

    • ProductAProductB 是实现了 IProduct 接口的具体产品类。

    • 每个产品类都有自己的 Operation 实现。

  3. 工厂接口 IFactory

    • 定义了一个 CreateProduct 方法,用于创建产品。

    • 所有具体工厂都需要实现这个接口。

  4. 具体工厂 FactoryAFactoryB

    • FactoryA 负责创建 ProductAFactoryB 负责创建 ProductB

    • 每个工厂类都实现了 IFactory 接口,并在 CreateProduct 方法中返回具体的产品实例。

  5. 主程序验证

    • Main 方法中,分别创建 FactoryAFactoryB 的实例。

    • 通过工厂的 CreateProduct 方法创建产品,并调用产品的 Operation 方法。

    • 输出结果验证了工厂方法模式的正确性。


输出结果

运行上述代码后,输出如下:

cs 复制代码
ProductA operation.
ProductB operation.

工厂方法模式的扩展性

如果需要增加新的产品类型,只需要增加一个新的具体产品类和对应的具体工厂类,而不需要修改现有代码。例如:

csharp

cs 复制代码
// 新增具体产品C
public class ProductC : IProduct
{
    public void Operation()
    {
        Console.WriteLine("ProductC operation.");
    }
}

// 新增具体工厂C
public class FactoryC : IFactory
{
    public IProduct CreateProduct()
    {
        return new ProductC();
    }
}

然后在 Main 方法中使用新的工厂:

csharp

cs 复制代码
IFactory factoryC = new FactoryC();
IProduct productC = factoryC.CreateProduct();
productC.Operation();

输出结果:

cs 复制代码
ProductC operation.

总结

工厂方法模式通过将对象的创建与使用分离,提高了代码的灵活性和可维护性。它符合开闭原则,易于扩展,适用于需要支持多种产品类型的场景。

相关推荐
△曉風殘月〆3 小时前
C#串口通信
嵌入式硬件·c#·串口
Hxyle8 小时前
c++设计模式
开发语言·c++·设计模式
摘星编程8 小时前
并发设计模式实战系列(17):信号量(Semaphore)
设计模式·并发编程
奥修的灵魂9 小时前
C#生成二维码和条形码
c#
琢磨先生David9 小时前
Java 企业级开发设计模式全解析
java·设计模式
不当菜虚困9 小时前
JAVA设计模式——(十一)建造者模式(Builder Pattern)
java·设计模式·建造者模式
codefly-xtl9 小时前
责任链设计模式
java·开发语言·设计模式
小浪学编程10 小时前
C#学习7_面向对象:类、方法、修饰符
开发语言·学习·c#
冼紫菜11 小时前
如何使用责任链模式优雅实现功能(滴滴司机、家政服务、请假审批等)
java·开发语言·设计模式·责任链模式
ValidationExpression11 小时前
设计模式-策略模式
python·设计模式·策略模式