动力节点首页 全国咨询热线:400-8080-105

绑定手机号,登录
手机号

验证码

微信登录
手机号登录
手机号

验证码

微信登录与注册
微信扫码登录与注册

扫码关注微信公众号完成登录与注册
手机号登录
首页 > 文章

Java抽象工厂模式

03-29 17:02 871浏览
举报 T字号
  • 大字
  • 中字
  • 小字

介绍:提供一个创建一系列相关的相互依赖对象的接口,而无需指定它们具体的类。它和工厂方法模式的区别就在于所创建对象的复杂度上。抽象工厂和简单工厂、工厂方法相比是最具一般性的。

场景:接着我们的pizza工厂,不过现在上头又增加了需求。他希望我们在中国pizza下面有番茄酱和沙拉酱两种口味,而美国pizza下面也有有番茄酱和沙拉酱两种口味。如果使用的是工厂方法模式,那么我们就需要再添加4种工厂分布制作不同的产品。

概念:

  • 产品树:中国番茄酱pizza和中国沙拉酱pizza处于同一等级结构(产品树),US番茄酱pizza和US沙拉酱pizza也处于同一等级结构(产品树)
  • 产品族:位于不同产品等级结构中功能相关联的产品组成的家族。中国番茄酱pizza与US番茄酱pizza属于同一产品族,中国沙拉酱pizza与US沙拉酱pizza属于同一产品族

优点:工厂方法模式针对的是一个产品等级结构;而抽象工厂模式则是针对的多个产品等级结构。

1.抽象工厂模式

介绍:我们将所有工厂的业务抽象出来,每个工厂必须实现对所有等级类别的产品的生产。每个子工厂用于实现一个产品族的生产。

披萨定义

// 中国番茄酱pizza
public class KetchupChinesePizza extends ChinesePizza {


    @Override
    public void addSeasoning() {
        System.out.println("添加番茄酱");
    }

}
// 美国番茄酱pizza
public class KetchupUSPizza extends USPizza {


    @Override
    public void addSeasoning() {
        System.out.println("添加番茄酱");
    }

}
// 中国沙拉酱pizza
public class SaladChinesePizza extends ChinesePizza {


    @Override
    public void addSeasoning() {
        System.out.println("添加沙拉酱");
    }

}
// 美国沙拉酱pizza
public class SaladUSPizza extends USPizza {


    @Override
    public void addSeasoning() {
        System.out.println("添加沙拉酱");
    }

}

抽象工厂

工厂需要能生产中国pizza和美国pizza

public abstract class PizzaFactory {
    public abstract ChinesePizza createChinesePizza();
    public abstract USPizza createUSPizza();
}

番茄酱工厂

能制作所有国家的番茄酱pizza

public class KetchupPizzaFactory extends PizzaFactory {
    @Override
    public ChinesePizza createChinesePizza() {
        System.out.println("开始制作中国pizza");
        KetchupChinesePizza pizza = new KetchupChinesePizza();
        pizza.addFlour();
        pizza.addWater();
        pizza.addSeasoning();
        return pizza;
    }

    @Override
    public USPizza createUSPizza() {
        System.out.println("开始制作美国pizza");
        KetchupUSPizza pizza = new KetchupUSPizza();
        pizza.addFlour();
        pizza.addWater();
        pizza.addSeasoning();
        return pizza;
    }

}

沙拉酱工厂

能制作所有国家的沙拉酱pizza

public class SaladPizzaFactory extends PizzaFactory {

    @Override
    public ChinesePizza createChinesePizza() {
        System.out.println("开始制作中国pizza");
        SaladChinesePizza pizza = new SaladChinesePizza();
        pizza.addFlour();
        pizza.addWater();
        pizza.addSeasoning();
        return pizza;
    }

    @Override
    public USPizza createUSPizza() {
        System.out.println("开始制作美国pizza");
        SaladUSPizza pizza = new SaladUSPizza();
        pizza.addFlour();
        pizza.addWater();
        pizza.addSeasoning();
        return pizza;
    }

}

提供pizza业务

public class TestMain {
    public static void main(String[] args) {
        PizzaFactory kf = new KetchupPizzaFactory();
        ChinesePizza pizza1 = kf.createChinesePizza();

        PizzaFactory sf = new SaladPizzaFactory();
        USPizza pizza2 = sf.createUSPizza();
    }
}

输出如下:

开始制作中国pizza
加400克面粉
加100ml水
添加番茄酱
开始制作美国pizza
加300克面粉
加100ml水
添加沙拉酱

不足:

如果我们再增加一个产品树(等级结构),比如巴西pizza,那么,我们需要为每个子工厂添加一个巴西披萨的制作方法。

2.静态抽象工厂

场景:为了对上面的不足加以调整,我们可以通过静态工厂结合抽象工厂,并通过反射机制来对pizza进行制作。

工厂类

public class SRFactory {

    public static ChinesePizza createChinesePizza(String name) throws Exception {
        System.out.println("开始制作中国pizza");
        ChinesePizza pizza = (ChinesePizza) Class.forName(name).newInstance();
        pizza.addFlour();
        pizza.addWater();
        pizza.addSeasoning();
        return pizza;
    }

    public static USPizza createUSPizza(String name) throws Exception {
        System.out.println("开始制作美国pizza");
        USPizza pizza = (USPizza) Class.forName(name).newInstance();
        pizza.addFlour();
        pizza.addWater();
        pizza.addSeasoning();
        return pizza;
    }

}

提供pizza业务

public static void main(String[] args) throws Exception {
    USPizza pizza = SRFactory.createUSPizza("com.bjpowernode.factory.model.KetchupUSPizza");
    ChinesePizza pizza2 = SRFactory.createChinesePizza("com.bjpowernode.designmodel.factory.model.SaladChinesePizza");
}

输出如下:

开始制作美国pizza
加300克面粉
加100ml水
添加番茄酱
开始制作中国pizza
加400克面粉
加100ml水
添加沙拉酱

总结:

工厂模式在具体实践中是使用比较频繁的,但是我们需要了解他们的长处和不足,根据特定情况来决定需要使用的模式。

  • 对于业务不会进行太多变更的,我们可以使用简单工厂
  • 对于只考虑产品树形式的(产品不会再细分子类),可以考虑工厂方法
  • 对于多个产品等级结构的,我们应该选择合适的抽象工厂
0人推荐
共同学习,写下你的评论
0条评论
我是码农
程序员我是码农

25篇文章贡献87343字

相关课程 更多>

作者相关文章更多>

推荐相关文章更多>

Java面试题及答案整理

提枪策马乘胜追击04-21 20:01

Spring常见面试题

代码小兵92504-17 16:07

Java零基础实战项目——五子棋

代码小兵98804-25 13:57

Java string类详解

杨晶珍05-11 14:54

6道经典算法面试题

杨晶珍05-12 16:39

发评论

举报

0/150

取消