版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_40780805/article/details/82945928
抽象工厂模式(Abstract Factory Pattern):工厂方法模式的升级版本,当有多个业务品种,业务分类的时候使用。
Provide an interface for creating families of related ro dependent objects without specifying their concrete classes.
为创建一组相关或相互依赖的对象提供提供一个接口,而且无需指向他们的具体类。
与工厂方法类似,抽象工厂也有四个角色:
- 抽象工厂(Abstract Factory)
- 具体工厂(Concrete Factory)
- 抽象产品(Abstract Product)
- 具体产品(Concrete Product)
抽象工厂针对的是一族产品,如果产品族中只有一种产品,则就为工厂方法而不是抽象工厂;
抽象工厂的缺点是产品族本身的扩展非常困难,如果要增加一个新的产品类型,则需要修改多个接口,并且会影响所有的已经存在的工厂类
比如,ThinkPad和ideaPad都是联想旗下的产品;ThinkPad有产品E460与E465;idaPad有产品320与330;
则根据抽象工厂定义有:
public class AbstractFactoryModel {
/**
* 抽象工厂模式
*/
public static void main(String[] args) {
//第一工厂
AbstractFactory factory=new AbFactory1_0();
factory.ideaPad().print();
factory.thinkpad().print();
//第二工厂
AbstractFactory factory2=new ABFactory2_0();
factory2.ideaPad().print();
factory2.thinkpad().print();
}
}
//定义ideaPad接口
interface IdeaPad{
public void print();
}
//ideaPad320实类
class IP320 implements IdeaPad{
@Override
public void print() {
System.out.println("ideaPad320");
}
}
//ideaPad330实类
class IP330 implements IdeaPad{
@Override
public void print() {
System.out.println("ideaPad330");
}
}
//定义thinkpad接口
interface Thinkpid{
public void print();
}
//thinkpad E460实类
class TPe460 implements Thinkpid{
@Override
public void print() {
System.out.println("ThinkPad E460");
}
}
//thinkpad E465实类
class TPe465 implements Thinkpid{
@Override
public void print() {
System.out.println("ThinkPad E465");
}
}
//抽象工厂接口
interface AbstractFactory{
IdeaPad ideaPad();
Thinkpid thinkpad();
}
//第一代工厂类
class AbFactory1_0 implements AbstractFactory{
@Override
public IdeaPad ideaPad() {
return new IP320();
}
@Override
public Thinkpid thinkpad() {
return new TPe460();
}
}
//第二代工厂类
class ABFactory2_0 implements AbstractFactory{
@Override
public IdeaPad ideaPad() {
return new IP330();
}
@Override
public Thinkpid thinkpad() {
return new TPe465();
}
}
参考书籍:《设计模式(Java版)》