看一个披萨的项目:要便于扩展,要便于维护
定义了一个创建对象的类,由这个类来封装实例化对象的行为
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-CoGGWbfu-1659338161878)(evernotecid://922396D6-A2D4-4855-AB42-2F266892D557/appyinxiangcom/13689298/ENResource/p1369)]](https://1000bd.com/contentImg/2022/08/03/234117682.png)
public class SimpleFactory {
//static 类方法
public static Pizza createPizza(String pizzaName){
Pizza pizza = null;
switch (pizzaName){
case "GreekPizza" :
pizza = new GreekPizza();
pizza.setName("希腊披萨");
break;
case "PepperPizza" :
pizza = new PepperPizza();
pizza.setName("胡椒披萨");
break;
default:
System.out.println("没有这个种类的披萨");
}
return pizza;
}
}
使用简单工厂方法
private static void simpleFactoryTest(){
do {
String pizzaName = getType();
Pizza pizza = SimpleFactory.createPizza(pizzaName);
if (pizza != null){
pizza.prepare();
pizza.bake();
pizza.cut();
pizza.box();
}else {
System.out.println("订购披萨失败");
break;
}
}while (true);
}
客户在点披萨时,可以点不同口味的披萨.比如 北京的奶酪pizza,北京的胡椒pizza,或者伦敦的奶酪pizza,伦敦的胡椒pizza.
2.思路
- 使用简单工厂模式,创建不同的简单工厂类,比如:BJPizzaSimpleFactory,LDPizzaSimpleFactory 等等.从当前这个案例来说,也是可以的,但是考虑到项目的规模,以及软件的可维护性,可扩展性不是特别好
- 使用工厂方法模式.
将披萨项目的实例化功能抽象成抽象方法,在不同的口味点餐子类中具体实现.
2.工厂方法模式 :
定义了一个创建对象的抽象方法,由子类决定要实例化的类.工厂方法模式将对象的实例化推迟到子类

abstract Pizza createPizza(String orderType);
public class LDOrderPizza extends OrderPizza {
@Override
Pizza createPizza(String orderType) {
Pizza pizza = null;
if(orderType.equals("cheese")) {
pizza = new LDCheesePizza();
} else if (orderType.equals("pepper")) {
pizza = new LDPepperPizza();
}
// TODO Auto-generated method stub
return pizza;
}
}
public class PizzaStore {
public static void main(String[] args) {
String loc = "bj";
if (loc.equals("bj")) {
//创建北京口味的各种Pizza
new BJOrderPizza();
} else {
//创建伦敦口味的各种Pizza
new LDOrderPizza();
}
// TODO Auto-generated method stub
}
}
定义了一个interface用于创建相关或有依赖关系的对象簇,而无需知名具体的类
![[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-Z0x4hvwN-1659338161885)(evernotecid://922396D6-A2D4-4855-AB42-2F266892D557/appyinxiangcom/13689298/ENResource/p1371)]](https://1000bd.com/contentImg/2022/08/03/234118201.png)
//一个抽象工厂模式的抽象层(接口)
public interface AbsFactory {
//让下面的工厂子类来具体实现
public Pizza createPizza(String orderType);
}
// 实现接口的方法
public class BJFactory implements AbsFactory{
@Override
public Pizza createPizza(String orderType) {
System.out.println("~使用的是抽象工厂模式~");
Pizza pizza = null;
if (orderType.equals("cheese")){
pizza = new BJCheesePizza();
}else if (orderType.equals("pepper")){
pizza = new BJPepperPizza();
}
return pizza;
}
}
public class OrderPizza {
AbsFactory factory;
public OrderPizza(AbsFactory factory){
setFactory(factory);
}
private void setFactory(AbsFactory factory){
System.out.println("setFactory");
Pizza pizza = null;
String orderType = "";
this.factory = factory;
do {
orderType = getType();
// factory 可能是北京的工厂子类,也可能是伦敦的工厂子类
pizza = factory.createPizza(orderType);
if (pizza != null) { // 订购ok
pizza.prepare();
pizza.bake();
pizza.cut();
pizza.box();
} else {
System.out.println("订购失败");
break;
}
} while (true);
}
}
public class PizzaStore {
public static void main(String[] args) {
new OrderPizza(new BJFactory());
}
}
将实例化对象的代码提取出来,放到一个类中统一管理和维护,达到主项目的依赖关系的解耦.从而提高项目的扩展和维护性.
- 简单工厂模式
- 工厂方法模式
- 抽象工厂模式
3.设计模式的依赖抽象原则
- 创建对象实例时,不要直接new 类, 而是把这个new 类的动作放在一个工厂的方法中,并返回.(变量不要直接持有具体类的引用)
- 不要让类继承具体类,而是继承抽象类或者实现interface(接口)
- 不要覆盖基类中已经实现的方法.