工厂方法模式

披萨项目需求

披萨项目新的需求:客户在点披萨时,可以点不同口味的披萨,比如北京的奶酪pizza、北京的胡椒pizza或者是伦敦的奶酪pizza、伦敦的胡椒pizza。

按照简单工厂模式,可以创建不同的简单工厂类,比如BJPizzaSimpleFactory、LDPizzaSimpleFactory等等.从当前这个案例来说,也是可以的,但是考虑到项目的规模,以及软件的可维护性、可扩展性并不是特别好。

在简单工厂类中,我们需要做如下实现:

//简单工厂类
public class SimpleFactory {
    //更加orderType 返回对应的Pizza 对象
    public Pizza createPizza(String orderType, String area) {
        Pizza pizza = null;
        System.out.println("使用简单工厂模式");
        if ("BJ".equals(area)){
            if (orderType.equals("pepper")) {
                pizza = new BJPepperPizza();
                pizza.setName(" 北京胡椒披萨 ");
            } else if (orderType.equals("cheese")) {
                pizza = new BJPepperPizza();
                pizza.setName(" 北京奶酪披萨 ");
            }
        }else if ("LD".equals(area)){
            if (orderType.equals("pepper")) {
                pizza = new LDPepperPizza();
                pizza.setName(" 伦敦胡椒披萨 ");
            } else if (orderType.equals("cheese")) {
                pizza = new LDCheesePizza();
                pizza.setName(" 伦敦奶酪披萨 ");
            }
        }else {
            // ...
        }
        return pizza;
    }
}

下面我们来看一下,如何使用工厂方法模式实现需求。

工厂方法模式

工厂方法模式介绍:

工厂方法模式设计方案:将披萨项目的实例化功能抽象成抽象方法,在不同的口味点餐子类中具体实现。

工厂方法模式:定义了一个创建对象的抽象方法,由子类决定要实例化的类。工厂方法模式将对象的实例化推迟到子类。

1、Pizza类

//将Pizza 类做成抽象
public abstract class Pizza {
	protected String name; //名字
	//准备原材料, 不同的披萨不一样,因此,我们做成抽象方法
	public abstract void prepare();
	public void bake() {
		System.out.println(name + " baking;");
	}
	public void cut() {
		System.out.println(name + " cutting;");
	}
	//打包
	public void box() {
		System.out.println(name + " boxing;");
	}
	public void setName(String name) {
		this.name = name;
	}
}

伦敦的胡椒pizza

public class LDPepperPizza extends Pizza{
	@Override
	public void prepare() {
		setName("伦敦的胡椒pizza");
		System.out.println(" 伦敦的胡椒pizza 准备原材料");
	}
}

北京的芝士pizza

public class BJCheesePizza extends Pizza {
	@Override
	public void prepare() {
		setName("北京的奶酪pizza");
		System.out.println(" 北京的奶酪pizza 准备原材料");
	}
}

2、披萨订购类

public abstract class OrderPizza {
    /** 定义一个抽象的方法,createPizza,让各个工厂子类自己实现 */
    public abstract Pizza createPizza(String orderType);
    // 构造器
    public OrderPizza() {
        Pizza pizza = null;
        String orderType; // 订购披萨的类型
        do {
            orderType = getType();
            pizza = createPizza(orderType); //抽象方法,由工厂子类完成
            //输出pizza 制作过程
            pizza.prepare();
            pizza.bake();
            pizza.cut();
            pizza.box();

        } while (true);
    }
    // 写一个方法,可以获取客户希望订购的披萨种类
    private String getType() {
        // ...
        return "pizza的种类:pepper、cheese口味."
    }
}

3、具体的子类pizza订购类

// 伦敦pizza订购类
public class LDOrderPizza extends OrderPizza {

	@Override
	public Pizza createPizza(String orderType) {

		Pizza pizza = null;
		if(orderType.equals("cheese")) {
			pizza = new LDCheesePizza();
		} else if (orderType.equals("pepper")) {
			pizza = new LDPepperPizza();
		}
		return pizza;
	}
}
// 北京pizza订购类
public class BJOrderPizza extends OrderPizza {
    @Override
    public Pizza createPizza(String orderType) {
        Pizza pizza = null;
        if(orderType.equals("cheese")) {
            pizza = new BJCheesePizza();
        } else if (orderType.equals("pepper")) {
            pizza = new BJPepperPizza();
        }
        return pizza;
    }
}

4、最后,还需要一个客户端,发出订购需求。

public class PizzaStore {
	public static void main(String[] args) {
		String loc = "bj";
		if (loc.equals("bj")) {
			//创建北京口味的各种Pizza
			new BJOrderPizza();
		} else {
			//创建伦敦口味的各种Pizza
			new LDOrderPizza();
		}
	}
}
posted @ 2019-11-14 08:17  开嘴的板栗  阅读(148)  评论(0编辑  收藏  举报