菜单 学习猿地 - LMONKEY

VIP

开通学习猿地VIP

尊享10项VIP特权 持续新增

知识通关挑战

打卡带练!告别无效练习

接私单赚外块

VIP优先接,累计金额超百万

学习猿地私房课免费学

大厂实战课仅对VIP开放

你的一对一导师

每月可免费咨询大牛30次

领取更多软件工程师实用特权

入驻
344
0

【设计模式】工厂方法模式

原创
05/13 14:22
阅读数 80484

定义


定义一个用于创建对象的接口,让子类决定实例化哪一个类。工厂方法使一个类的实例化延迟到其子类

优缺点


  • 优点

针对简单工厂不容易扩展,工厂方法将实例化延迟到子类工厂,从而提供扩展

  • 缺点

每次新增产品都需要添加工厂和具体产品类,增加系统复杂性

角色


  • 客户端 --> 抽象工厂,具体工厂, 抽象产品
  • 抽象产品 --> 具体产品
  • 具体产品
  • 抽象工厂 --> 抽象产品
  • 具体工厂 --> 抽象产品,具体产品

代码


  • 抽象产品
public abstract class Phone
{
    public abstract void Call();
}
  • 具体产品
public class IPhone : Phone
{
    public override void Call()
    {
        System.Console.WriteLine("Call by IPhone");
    }
}
public class AndroidPhone : Phone
{
    public override void Call()
    {
        System.Console.WriteLine("Call by Android");
    }
}
  • 抽象工厂
public abstract class PhoneFactory
{
    public abstract Phone Create();
}
  • 具体工厂
public class IPhoneFactory : PhoneFactory
{
    public override Phone Create()
    {
        return new IPhone();
    }
}
public class AndroidFactory : PhoneFactory
{
    public override Phone Create()
    {
        return new AndroidPhone();
    }
}
  • 客户端
Phone phone = new IPhoneFactory().Create();
phone.Call();

phone = new AndroidFactory().Create();
phone.Call();

简单工厂 VS 工厂方法

假设现在需要扩展手机产品,增加鸿蒙OS手机

  • 简单工厂
  1. 增加具体手机类 HarmonyPhone
  2. 修改静态工厂方法增加HarmonyPhone判断(违反开闭原则)
  • 工厂方法
  1. 增加具体手机类 HarmonyPhone
  2. 增加具体工厂类 HarmonyFactory

总结

工厂方法模式是典型的解耦框架,通过增加抽象工厂,客户端与具体产品解耦,抽象工厂与具体产品解构

符合迪米特法则,不需要知道具体产品如何构造

符合依赖倒置原则,只依赖产品类的抽象

符合里氏替换原则,父类出现的地方都可以用子类替换,因为没有破坏继承体系

当然最重要复合开闭原则,当需要扩展产品时,并不需要改动原来代码,只需增加新的具体产品类,具体工厂类


示例代码 - Github

发表评论

0/200
344 点赞
0 评论
收藏
为你推荐 换一批