一、简单工厂模式
简单工厂的定义:提供一个创建对象实例的功能,而无须关心其具体实现。被创建实例的类型可以是接口、抽象类,也可以是具体的类
实现汽车接口
public interface Car {
String getName();
}
奔驰类
public class Benz implements Car {
@Override
public String getName() {
return "Benz";
}
}
宝马类
public class BMW implements Car {
@Override
public String getName() {
return "BMW";
}
}
简单工厂,既能生产宝马又能生产奔驰
public class SimpleFactory {
public Car getCar(String name){
if("BMW".equals(name)){
return new BMW();
}else if("Benz".equals(name)){
return new Benz();
}else{
System.out.println("没有个产品");
return null;
}
}
}
测试类
public class SimpleFactoryTest {
public static void main(String[] args) {
SimpleFactory simpleFactory = new SimpleFactory();
Car bmw = simpleFactory.getCar("BMW");
System.out.println(bmw.getName());
}
}
测试结果
BMW
根据简单工厂的定义,用户只要产品而不在乎产品如何生产,看起来好像很完美的样子。但大家想想,这个世界存在什么都生产的工厂吗?
显然是不存在的,每一个汽车品牌都有自己的生产工厂,都有自己生产技术。映射到spring框架中,我们有很多很多种的bean需要生产,如果只依靠一个简单工厂来实现,那么我们得在工厂类中嵌套多少个if…else if啊?
而且我们在代码中生产一辆汽车只是new一下就出来了,但实际操作中却不知道需要进行多少操作,加载、注册等操作都将体现在工厂类中,那么这个类就会变得紊乱,管理起来也很不方便,所以说每个品牌应该有自己的生产类。
因为专一,所以专业嘛,这个时候工厂方法就出现了。
二、工厂方法
工厂接口
public interface Factory {
String getName();
}
奔驰工厂
public class BenzFactory implements Factory {
@Override
public String getName() {
return new Benz().getName();
}
}
宝马工厂
public class BMWFactory implements Factory {
@Override
public String getName() {
return new BMW().getName();
}
}
测试类
public class SimpleFactoryTest {
public static void main(String[] args) {
Factory factory = new BenzFactory();
String name = factory.getName();
System.out.println(name);
}
}
测试结果
BMW
Benz
根据上述代码可以看出,不同品牌的汽车是由不同的工厂生产的,貌似又是很完美的。但大家看一下测试类,当一个人想要去买一辆宝马汽车的时候(假设没有销售商),那么他就要去找宝马工厂给他生产一辆,过几天又想要买一辆奔驰汽车的时候,又得跑到奔驰工厂请人生产,这无疑就增加了用户的操作复杂性。所以有没有一种方便用户操作的方法呢?这个时候抽象工厂模式就出现了。
三、抽象工厂
抽象工厂
默认工厂
宝马工厂
奔驰工厂
测试类
测试结果
Benz
根据上述代码可以看出,用户需要一辆汽车,只需要去找默认的工厂提出自己的需求(传入参数),便能得到自己想要产品,而不用根据产品去寻找不同的生产工厂,方便用户操作。