HeadFirst设计模式-工厂模式(3)-工厂方法

接上文。

披萨店改造的做法实际是“工厂方法”设计模式,原本由一个对象负责所有具体类的实例化,现在通过对PizzaStore做一些转变,变成由一群子类类负责实例化。

工厂方法模式

工厂方法模式定义了一个创建对象的接口,但由子类决定要实例化的类是哪一个。工厂方法让类把实例化推迟到子类。

abstract Product factoryMethod(String type)

工厂方法用来处理对象的创建,并将这样的行为封装在子类中。这样,客户程序中伏案与超类的代码就和子类对象创建代码解耦了。

代码里减少对于具体类的依赖是件好事。引入一个设计原则:

设计原则

要依赖,不要依赖具体类。

这个原则说明了,不能让高层组件依赖低层组件。而且,不管高层或低层组件,两者都应该依赖于抽象。

比如比萨店的椅子,PizzaStore是高层组件,而比萨实现是低层组件。很明显,PizzaStore天然依赖这些具体比萨类。

上面比萨店例子应用这个原则的过程是,在PizzaStore类中将实例化披萨对象的代码独立出来,建立一个工厂方法,这样高层组件(PizzaStore)和低层组件(比萨具体类)都依赖了Pizza抽象,遵循了依赖倒置原则。

依赖倒置,这里的倒置实际是倒置了我们思考的方式,原低层->高层的方式,即比萨->比萨店,倒置为高层->低层,即比萨店->比萨,并且都依赖接口。

确保原料的一致

现在,比萨店的成功关键在于新鲜、高质量的原料,但是有一些加盟店,使用低价原料来增加利润。那么,如何确保煤价加盟店使用高质量的原料呢?请看下篇《HeadFirst设计模式-工厂模式(4)-抽象工厂》。

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值