工厂方法模式(Factory Method Pattern)是一种创建型设计模式,它定义了一个用于创建对象的接口,但将具体的对象创建延迟到子类中进行。这样可以使一个类的实例化延迟到其子类中,从而实现了对对象的创建过程的解耦。
在工厂方法模式中,有四个主要角色:
- 产品(Product):定义了工厂方法创建的对象的接口。
- 具体产品(Concrete Product):实现了产品接口的具体类。
- 工厂(Factory):定义了创建产品对象的抽象方法,由子类实现具体的创建逻辑。
- 具体工厂(Concrete Factory):实现了工厂接口,负责创建具体产品的实例。
代码实现
interface Product {
void operation();
}
// 具体产品A
class ConcreteProductA implements Product {
@Override
public void operation() {
System.out.println("ConcreteProductA operation");
}
}
// 具体产品B
class ConcreteProductB implements Product {
@Override
public void operation() {
System.out.println("ConcreteProductB operation");
}
}
// 工厂接口
interface Factory {
Product createProduct();
}
// 具体工厂A
class ConcreteFactoryA implements Factory {
@Override
public Product createProduct() {
return new ConcreteProductA();
}
}
// 具体工厂B
class ConcreteFactoryB implements Factory {
@Override
public Product createProduct() {
return new ConcreteProductB();
}
}
// 示例用法
public class Main {
public static void main(String[] args) {
Factory factoryA = new ConcreteFactoryA();
Product productA = factoryA.createProduct();
productA.operation(); // 输出:ConcreteProductA operation
Factory factoryB = new ConcreteFactoryB();
Product productB = factoryB.createProduct();
productB.operation(); // 输出:ConcreteProductB operation
}
}
总结
工厂方法模式的优点包括:
- 降低了代码的耦合性:客户端只需要依赖于产品的抽象接口和工厂接口,无需关心具体产品的实现细节。
- 增加了系统的可扩展性:当需要添加新产品时,只需要创建对应的具体产品类和具体工厂类即可,无需修改现有代码。
- 符合开闭原则:对扩展开放,对修改关闭。
工厂方法模式的缺点包括:
- 增加了系统的复杂度:引入了新的工厂接口和具体工厂类,增加了系统的抽象性和理解难度。
- 每增加一个产品,就需要创建一个对应的具体产品类和具体工厂类,增加了系统的代码量。
总结来说,工厂方法模式适用于需要创建的对象较多且需要灵活扩展的场景,它提供了一种统一的对象创建方式,并且符合面向对象的设计原则。