简单工厂模式(静态工厂方法模式)

本文深入讲解了简单工厂模式的概念、实现方法及优缺点,通过Java代码示例详细展示了如何使用简单工厂模式创建不同实例,同时探讨了其在软件设计中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

定义:

简单工厂模式(Simple Factory Pattern):定义一个工厂类,它可以根据参数的不同返回不同的实例,被创建的实例通常都具有相同的父类。因为在简单工厂模式中用于创建实例的方法是静态(static)方法,因此简单工厂模式又被称为静态工厂方法(Static Factory Method)模式,它属于类创建型模式。

严格来讲,简单工厂模式并不属于23中设计模式,但是它在软件设计和开发中也经常使用,而且学习它可以帮助我们更加深入理解其他工厂模式。

简单工厂模式的UML图如下所示:

简单工厂模式实现的方法是:

首先将需要创建的各种不同对象的相关代码封装到不同的类中,这些类称为具体产品类,而将它们的公共的代码进行抽象和提取后,封装在一个抽象产品类中,每一个具体产品类都是抽象产品类的子类;

然后提供一个工厂类用于创建各种产品,在工厂类中提供一个创建产品的工厂方法,该方法可以根据所传入的参数的不同创建不同的具体产品对象,客户端只需调用工厂类的工厂方法并传入相应的参数即可得到一个具体产品对象。

简单工厂模式的要点在于:

当你需要什么具体产品对象,只需要传入一个正确的参数,就可以得到你需要的对象,而无需知道其创建的细节。

简单工厂模式的Java代码实现如下:


/**
 * 抽象产品类
 */
public abstract class Product {

    //所有产品类的公共业务方法
    public void methodSame() {
        //公共方法的实现
    }

    //声明抽象的业务方法,由不同的产品子类来实现
    public abstract void methodDiff();

}
/**
 * 具体产品类
 */
public class ConcreteProductA extends Product {

    //实现具体的业务方法
    @Override
    public void methodDiff() {

    }
}
/**
 * 具体产品类
 */
public class ConcreteProductB extends Product {

    //实现具体的业务方法
    @Override
    public void methodDiff() {

    }
}
/**
 * 工厂类
 */
public class Factory {


    //静态工厂方法,根据所传的参数,创建不同的具体产品
    public static Product getProduct(String arg) {
        Product product = null;
        if ("A".equals(arg)) {
            product = new ConcreteProductA();
        } else if ("B".equals(arg)) {
            product = new ConcreteProductB();
        }

        return product;
    }
}


public class Client {

    public static void main(String[] args) {
        //在客户端类中,通过工厂类创建具体产品对象
        Product product = Factory.getProduct("A");
        product.methodSame();
        product.methodDiff();
    }
}

简单工厂模式提供了专门的工厂类用于创建对象,将对象的创建和对象的使用分离开,它的主要优点如下:

1.工厂类包含必要的判断逻辑,可以决定在什么时候创建哪一个产品类的实例,客户端可以免除直接创建产品对象的职责,而仅仅“消费”产品。简单工厂模式实现了对象的创建和使用分离;

2.客户端无须知道所创建的具体产品类的类名,只需要知道具体产品类所对应的参数即可,对应一下复杂的类名,通过简单工厂模式可以在一定程度上减少使用者的记忆量;

3.通过引入配置文件,可以在不修改任何客户端代码的情况下更换和增加新的具体产品类,在一定程度上提高了系统的灵活性。

简单工厂模式的主要缺点如下:

1.由于工厂类集中了所有产品的创建逻辑,职责过重,一旦不能正常工作,整个系统都要受到影响;

2.使用简单工厂模式势必会增加系统中类的个数(引入了新的工厂类),增加了系统的复杂度和理解难度;

3.系统扩展困难,一旦添加新产品就不得不修改工厂类的逻辑,在产品类型较多时,有可能会造成工厂类的逻辑过于复杂,不利于系统的扩展和维护;

4.简单工厂模式由于使用了静态工厂方法,造成工厂角色无法形成基于继承的等级机构。

简单工厂模式的适用场景如下:

1.工厂类负责创建的对象比较少,由于创建的对象较少,不会造成工厂方法中的业务逻辑太过复杂;

2.客户端只知道传入工厂类的参数,对于如何创建对象并不关心。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值