一、抽象工厂模式:
抽象工厂模式(Abstract Factory Pattern):提供一个创建一系列相关或相互依赖对象的接口,而无须指定它们具体的类。
与工厂方法模式相比,抽象工厂模式中的具体工厂不只是创建一种产品,它负责创建一族产品,而与工厂方法相比抽象工厂模式的工厂类比工厂方法模式少(工厂方法模式中每个产品对应一个工厂,也就是一个工厂只负责生产某一特定产品,而抽象工厂模式则只需一个工厂,该工厂通过接口生产一族产品)。
二、代码实现
1、抽象工厂:
package com.mycompany.app.abst;
import com.mycompany.app.Fruit;
public abstract class AbstractFactory {
public abstract Fruit getApple();
public abstract Fruit getBanana();
public abstract Fruit getOrange();
}
该抽象工厂定义了三个接口,分别生产对应的苹果、香蕉、橘子三种产品。
2、工厂实现:
package com.mycompany.app.abst;
import com.mycompany.app.Apple;
import com.mycompany.app.Banana;
import com.mycompany.app.Fruit;
import com.mycompany.app.Orange;
public class FruitFactory extends AbstractFactory {
public Fruit getApple() {
return new Apple();
}
public Fruit getBanana() {
return new Banana();
}
public Fruit getOrange() {
return new Orange();
}
}
该工厂实现了抽象工厂(使用抽象类主要考虑抽象类可实现一些共有(苹果、香蕉、橘子三种产品共有的)的逻辑)
3、实体类:
苹果、香蕉、橘子实体类请参照https://blog.csdn.net/up123456789/article/details/87738537。
4、测试类:
package com.mycompany.app.abst;
public class AbstractFactoryTest {
public static void main(String[] args) {
AbstractFactory factory = new FruitFactory();
System.out.println("购买苹果 = " + factory.getApple().getName());
System.out.println("购买香蕉 = " + factory.getBanana().getName());
System.out.println("购买橘子 = " + factory.getOrange().getName());
}
}
5、测试结果:
购买苹果 = 苹果
购买香蕉 = 香蕉
购买橘子 = 橘子
Process finished with exit code 0