码迷,mamicode.com
首页 > 其他好文 > 详细

设计模式------厂三姐妹

时间:2015-07-08 14:25:39      阅读:117      评论:0      收藏:0      [点我收藏+]

标签:

      设计模式完成学业,我是一个研究躺在订单,有三种模式其名称中包含“工厂”这个词眼,。它们就是“工厂三姐妹”,以下我们通过计算器的演示样例来好好认识一下这姐妹三儿。

简单工厂模式:

技术分享

简单工厂类中的代码:

技术分享

       从中我们能够看到。当用户请求进行加法运算时,仅仅需operationFactory.createOperate("+"),工厂就会自己主动给出一个加法类的实例,用户根本不用和详细的运算类打交道,对象的创建过程被封装起来了。

可是假设我们要加入一个幂运算,不仅要在运算类下加入幂运算的子类来扩展,还须要修改工厂类,加入新的case。这样对修改也开放了。简单工厂模式就是由于违背了开闭原则,而不能算得上一个真正的设计模式。

当工厂类负责创建的对象比較少且不再增减,客户仅仅知道传入工厂类的參数的情况下,使用简单工厂模式是个不错的选择。

工厂方法模式:

技术分享

同简单工厂模式相比,我们能清晰地看到工厂类下多了详细运算的工厂子类,工厂类接口的任务不那么繁重了,仅仅有一个创建抽象产品的方法:

技术分享

        全部生产详细产品类的工厂。都要实现这个接口。client的代码变成了这种:

IFactory operFactory=new AddFactory();Operation oper=operFactory.CreateOperation();

       这样就让子类去决定实例化详细的类了。分工更细了,责任到人。这时候,我们要加入幂运算仅仅需在工厂类和运算类下分别扩展一下,而不用改动代码了,弥补了简单工厂模式的不足之处。

       当须要生产一系列的产品时,比方说有两种级别的计算器,一种是我们常见的算术型计算器,一种是科学型计算器。它们都能计算加减乘除,而工厂方法模式实现的仅仅是一种计算器。这个时候,就要用抽象工厂模式了,真可谓山外有山,人外有人。

抽象工厂模式:

技术分享

(自己举得样例。有不妥之处。请谅解)

        这样一来。客户能够更换产品的系列,想要算术型计算器,IFactory=new  ArithmeticFactory()。想要科学型的,IFactory=new  ScienceFactory()。

工厂方法模式与抽象工厂模式的差别事实上就是两句话:前者仅仅有一个抽象产品类。而后者有多个。前者的详细工厂类仅仅能创建一个详细产品类的实例,而抽象工厂模式能够创建多个。

纵观这三种模式,长江后浪推前浪。但不要以为抽象工厂模式就非常完美了,当我们要加入乘法运算呢?不仅有扩展还有修改。学习要灵活,这三姐妹能够互相帮助呀,能够让简单工厂模式来改进抽象工厂模式。事实上在全部用到简单工厂的地方,都能够考虑反射技术来去除switch或if,解除分支推断带来的耦合。

办法总比困难多的。

这姐妹三儿就介绍到这儿了。今天先混个脸熟。以后打交道的日子多着呢。




版权声明:本文博客原创文章,博客,未经同意,不得转载。

设计模式------厂三姐妹

标签:

原文地址:http://www.cnblogs.com/gcczhongduan/p/4629890.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!