美文网首页
2、Factory工厂模式

2、Factory工厂模式

作者: 冰镇柠檬_tree | 来源:发表于2019-03-29 17:21 被阅读0次

    1、描述

    • 工厂模式的本质就是用工厂方法代替new操作创建一种实例化对象的方式。
    • 在创建对象时不会对客户端暴露创建逻辑,并且是通过使用一个共同的接口来指向新创建的对象。
    • 工厂模式可分为简单工厂模式,工厂方法模式和抽象工厂模式三类。

    2.1 简单工厂模式

    • 简单工厂模式属于类的创建型模式,又叫静态工厂方法模式。通过专门定义一个工厂类来负责创建其他类的实例,被创建的实例通常都具有共同的父类。

    2.1.1 简单工厂模式含有3个角色

    1)工厂角色(Creator)

    这是简单工厂模式的核心,它用来负责实现创建所有实例的内部逻辑。工厂类可以被外界直接调用,创建所需的产品对象。

    public class CarFactory {
       public static Car creatCar(String type){
           Car car= null;
           // 这里我们通过switch来判断,具体制作哪一个品牌的车
           switch(type){
               case "Benz":
                   car= new Benz();
                   break;
               case "BYD":
                   car= new BYD();
                   break;
               case "Bentley ":
                   car= new Bentley();
                   break;
               default:
                   break;
           }
           return car;
       }
    }
    
    2)抽象角色(Product)

    这是简单工厂模式所创建的所有对象的父类,它负责描述所有实例所共有的公共接口。该类可以是接口,也可以是抽象类。

    public interface Car{
        public void run();
    }
    
    3)具体产品角色(Concrete Product)

    简单工厂模式所创建的具体的实例对象。

    public class Benz implements Car{
        public void run(){
            System.out.println("这是Benz");
        }
    }
    
    public class BYD implements Car{
        public void run() {
            System.out.println("这是BYD");
        }
    }
    
    public class Bentley implements Car{
        public void run(){
            System.out.println("这是Bentley");
        }
    } 
    
    4)测试用例
    //通过统一的工厂,传入不同参数调用生产汽车的方法去生产不同品牌的车
    public class Client {
        public static void main(String[] args) {
            Car benz= CarFactory.creatCar("Benz");
            benz.run();
    
            Car byd= CarFactory.creatCar("BYD");
            byd.run();
    
            Car bentley = CarFactory.creatCar("Bentley");
            bentley.run();
        }
    } 
    

    2.1.2 结论

    简单工厂模式实现了生成产品类的代码跟客户端代码分离,在工厂类中你可以添加所需的生成产品的逻辑代码,但是问题来了,优秀的java代码是符合“开放-封闭”原则的,也就是说对扩展开发,对修改关闭,如果你要加一个产品类C,就要增加if-else判断,修改工厂类里面的生成产品的代码。

    2.2 工厂方法模式

    • 工厂方法模式是对普通工厂方法模式的改进,在普通工厂方法模式中,如果传递的字符串出错,则不能正确创建对象,而工厂方法模式是提供多个工厂方法,分别创建对象。
    • 可以实现“开发-封闭”原则,无论加多少产品类,我们都不用修改原来类中的代码,而是通过增加工厂类来实现。但是这还是有缺点的,如果产品类过多,我们就要生成很多的工厂类。
    2.2.1. 和简单工厂模式一样,先定义一个接口。再定义Benz、BYD和Bentley去实现这个接口
    public interface Car{
        public void run();
    }
    
    public class Benz implements Car{
        public void run(){
            System.out.println("这是Benz");
        }
    }
    
    public class BYD implements Car{
        public void run() {
            System.out.println("这是BYD");
        }
    }
    
    public class Bentley implements Car{
        public void run(){
            System.out.println("这是Bentley");
        }
    } 
    
    2.2.2. 定义工厂接口
    public interface CarFactory {
        public Car createCar();
    }
    
    2.2.3. 再分别定义BenzFactory、BYDFactory、BentleyFactory,继承刚刚定义的工厂接口
    public class BenzFactory implements CarFactory {
    
       public Car createCar(){
           return new Benz();
       }
    }
    
    public class BYDFactory implements CarFactory {
    
       public Car createCar(){
           return new BYD();
       }
    }
    
    public class BentleyFactory implements CarFactory {
    
       public Car createCar() {
           return new Bentley();
       }
    } 
    
    2.2.4. 测试用例
    // 客户端代码
    public class Client {
        public static void main(String[] args) {
            //生产Benz
            CarFactory benzFactory= new BenzFactory();
            Car benz= benzFactory.createCar();
            benz.run();
    
            //生产BYD
            CarFactory bydFactory = new BYDFactory();
            Car byd= bydFactory.createCar();
            byd.run();
    
            //生产Bently
            CarFactory bentleyFactory = new BentleyFactory();
            Car bentley= bentleyFactory.createCar();
            bentley.run();
        }
    } 
    

    2.3 抽象工厂模式

    • 假如我们要实现的产品接口不止一个,也就是有多个产品接口,不同产品接口有对应的产品族。什么是产品族呢?简单的理解就是,不同牌子产的车里面会有跑车类型,家庭类型,商用类型等的车,不同牌子的车的跑车类型的车可以组成一个产品族。对于这种情况我们可以采用抽象工厂模式。
      抽象工厂模式中包含的角色及职责:
    1.抽象工厂角色(Creator)

    这是抽象工厂模式的核心,任何工厂类必须实现这个接口。
    1.1 定义工厂接口

    public interface CarFactory {
    
        public SUVCar createSUVCar();
    
        public SportsCar createSportsCar();
    }
    
    2.具体工厂角色(Concrete Creator)

    2.1它是抽象工厂的一个实现,负责实例化产品对象。
    定义三个工厂类继承上边的接口并实现其方法

    public class BenzFactory implements CarFactory {
        public SUVCar createSUVCar(){
            return new SUVBenz();
        }
        public SportsCar createSportsCar(){
            return new SportsBenz();
        }
    } 
    
    public class BYDFactory implements CarFactory {
        public SUVCar createSUVCar(){
            return new SUVBYD();
        }
        public SportsCar createSportsCar(){
            return new SportsBYD();
        }
    } 
    
    public class BentleyFactory implements CarFactory {
        public SUVCar createSUVCar(){
            return new SUVBentley();
        }
        public SportsCar createSportsCar(){
            return new SportsBentley();
        }
    } 
    
    3.抽象角色(Product)

    抽象工厂模式所创建的所有对象的父类,它负责描述所有实例所共有的公共接口。
    3.1 不同型号的汽车

    public interface SUVCar {
    
        public void run();
    
    }
    
    public interface SportsCar {
    
        public void run();
    
    }
    
    4.具体产品角色(Concrete Product)

    抽象工厂模式所创建的具体的实例对象。
    4.1 定义各个型号的汽车,继承刚刚定义的接口,实现其方法

    public class SUVBenz implements SUVCar {
        public void run() {
            System.out.println("这是SUVBenz");
        }
    }
    
    public class SportsBenz implements SportsCar {
        public void run() {
            System.out.println("这是SportsBenz");
        }
    } 
    public class SUVBYD implements SUVCar {
        public void run() {
            System.out.println("这是SUVBYD ");
        }
    }
    
    public class SportsBYD implements SportsCar {
        public void run() {
            System.out.println("这是SportsBYD ");
        }
    } 
    public class SUVBentley implements SUVCar {
        public void run() {
            System.out.println("这是SUVBentley ");
        }
    }
    
    public class SportsBentley  implements SportsCar {
        public void run() {
            System.out.println("这是SportsBentley  ");
        }
    } 
    
    5. 测试用例
    public class Client {
        public static void main(String[] args) {
            //生产Benz
            CarFactory benzFactory = new BenzFactory();
            SUVCar suvBenz= benzFactory .createSUVCar();
            SportsCar sportsBenz = benzFactory .createSportsCar();
            suvBenz.run();
            sportsBenz.run();
            //生产BYD 
            CarFactory bydFactory = new BYDFactory();
            SUVCar suvBYD = bydFactory.createSUVCar();
            SportsCar sportsBYD  = bydFactory.createSportsCar();
            suvBYD.run();
            sportsBYD.run();
             //生产Bentley 
            CarFactory bentleyFactory = new BentleyFactory();
            SUVCar suvBentley= bentleyFactory .createSUVCar();
            SportsCar sportsBentley  = bentleyFactory .createSportsCar();
            suvBentley.run();
            sportsBentley.run();
        }
    } 
    
    6. 结论
    • 简单工厂模式:工厂类是整个模式的关键所在,包含了必要的逻辑判断,能够外界给定的信息, 决定究竟创建哪个具体类的对象。
    • 工厂方法模式:是对简单工厂方法模式的一个抽象,抽离出了一个Factory类(或者接口),这个接口不负责具体产品的生产,而只是指定一些规范,具体的生产工作由其子类去完成。这个模式中,工厂类和产品类往往是一一对应的,完全解决了简单工厂模式中违背“开闭原则”的问题,实现了可扩展;
    • 抽象工厂模式 :存在多个抽象产品类,每个抽象产品类可以派生出多个具体产品类,工厂提供多种方法,去生产“系列”产品。

    相关文章

      网友评论

          本文标题:2、Factory工厂模式

          本文链接:https://www.haomeiwen.com/subject/fuvlbqtx.html