为汽车工厂也例,首先来个汽车类的接口 Car,里面有只发车的方
drive(),然后来个宝马车的类 BMW 和奔驰车的类 Benz 实现了 Car 接口。

新能源车 1新能源车 2

public interface Car{
    public void drive();
}

public class BMW implements Car{
    public BMW(){
        System.out.println("生产一台宝马车");
    }

    public void drive(){
        System.out.println("我开宝马车");
    }
}

public class Benz implements Car{
    public Benz(){
        System.out.println("生产一台奔驰车");
    }

    public void drive(){
        System.out.println("我开奔驰车");
    }
}

View Code

    现在只要只要就此 BMW 这个近乎,最中心的艺术是:BMW bmw = new
BMW();  如果还要个 Benz 类,就得:new Benz();

  这样每个都得 new 个汽车对象,但是宝马和奔驰还属于汽车,都出 drive()
方法;那咱们是不是能够创建一个生育汽车之工厂,

  然后想只要啊汽车告诉工厂,工厂帮你养就是可以了,而非用无生儿育女的细节(也就算是
new 对象的经过),这样见面再度好呢?

  到者,简单工厂模式就是出去了。

 

一. 大概工厂模式

新能源车 3新能源车 4

public class CarFactory{
    public static Car createCar(String carName){
        if("BMW".equals(carName)){
            return new BMW();
        }else if("Benz".equals(carName)){
            return new Benz();
        }
    }
}

View Code

  如果要生一样光汽车,直接调用 Car car = CarFactory.createCar(“BMW”);
就可以了。

    这种工厂则老好,但是每次要入新车还得改工厂类来参加新的判定语句,不适合开闭原则;

  所以又出矣平等种更好的生产方式,这即是工厂方法模式。

 

二. 工厂方法模式

  首先抽象出一个产汽车的厂子类接口,然后叫现实工厂类实现这个接口,这样虽生出宝马车生产工厂、奔驰车生产工厂。

新能源车 5新能源车 6

public interface CarFactory{
    public static Car createCar();
}

public class BMWFactory implements CarFactory{
    public static Car createCar(){
        return new BMW();
    }
}

public class BenzFactory implements CarFactory{
    public static Car createCar(){
        return new Benz();
    }
}

View Code

   这样的补就是是使本身还要生产长城汽车,不用去修改 CarFactory
工厂,只要写单长城工厂类去实现CarFactory接口就好了。

 

    随着社会的上进,汽车类型也差不多矣,比如分为越野车和走车少独密密麻麻,这样原本 Car 接口就未能够通用,

  而变成 YueYeChe 和 PaoChe
两独接口,而更加野车适合当巅峰走,跑车符合在赛路上跑,drive
的道也改变了,如下:

新能源车 7新能源车 8

public interface YueYeChe{
    public void driveShanLu();
}

public interface PaoChe{
    public void driveSaiLu();
}

View Code

  而宝马和奔驰还养跑车和更加野车:

新能源车 9新能源车 10

public BMWYueYeChe implements YueYeChe{
    public void driveYueYeChe(){
        System.out.println("我在山路上开宝马越野车");
    }
}

public BMWPaoChe implements PaoChe{
    public void drivePaoChe(){
        System.out.println("我在赛路上开宝马跑车");
    }
}

public BenzYueYeChe implements YueYeChe{
    public void driveYueYeChe(){
        System.out.println("我在山路上开奔驰越野车");
    }
}

public BenzPaoChe implements PaoChe{
    public void drivePaoChe(){
        System.out.println("我在赛路上开奔驰跑车");
    }
}

View Code

  

    按照工厂方法模式,我们得 YueYeCheFactory 和 PaoCheFactory
两单厂子接口,以及 BMWYueYeCheFactory 、

  BMWPaoCheFactory、BenzYueYeCheFactory 、BenzPaoCheFactory
四只具体工厂类。如果欲再生产其他车,工厂类

  会呈指数增长,难以保障。如果能对厂接口进行扩张,不是再好?这样虽有了抽象工厂模式。

 

三. 抽象工厂模式

    工厂方法模式相似是对同栽系列之纸上谈兵产品之养,为成为可以对多密密麻麻的出品进行生产,而将工厂方法模式进行扩展,

  这即是空泛工厂模式。因为 Car 类分成了跑车和越野车,所以扩充后的厂接口也不怕可知生起跑车及更加野车。这样,宝马工厂类

  可以生产宝马跑车和宝马越野车,奔驰工厂类可生育奔驰跑车和奔驰越野车。

新能源车 11新能源车 12

public interface CarFactory{
    public static PaoChe createPaoChe();
    public static YueYeChe createYueYeChe();
}

public BMWFactory implements CarFactory{
    public static PaoChe createPaoChe(){
        return new BMWPaoChe();
    }

    public static YueYeChe createYueYeChe(){
        return new BMWYueYeChe();
    }
}

public BenzFactory implements CarFactory{
    public static PaoChe createPaoChe(){
        return new BenzPaoChe();
    }

    public static YueYeChe createYueYeChe(){
        return new BenzYueYeChe();
    }
}

View Code

 

网站地图xml地图