设计模式学习总结(3) 抽象工厂
2014-03-20 23:49
197 查看
本系列主要记录设计模式的意图是什么,它要解决一个什么问题,什么时候可以使用它;它是如何解决的,掌握它的结构图,记住它的关键代码;能够想到至少两个它的应用实例,一个生活中的,一个软件中的;这个模式的优缺点是什么,其有哪些使用场景,在使用时要注意什么。
尊重作者,转载请注明晔阳的Bloghttp://blog.csdn.net/hacke2
3.抽象工厂
意图:提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类
主要解决:主要解决接口选择的问题
什么时候使用:系统的产品有多于一个的产品族,而系统只消费其中某一族的产品
如何解决 :在一个产品族里面,定义多个产品
结构图:
关键代码:在一个工厂里聚合多个同类产品
应用实例:工作了,为了参加一些聚会,肯定有两套或多套衣服吧,比如说有商务装(成套,一系列具体产品)、时尚装(成套,一系列具体产品),甚至对于一个家庭来说,可能有商务女装、商务男装、时尚女装、时尚男装,这些也都是成套的,即一系列具体产品.咱们假设一种情况(现实中是不存在的,要不然,没法进入共产主义了,但有利于说明抽象工厂模式),在你的家中,某一个衣柜(具体工厂)只能存放某一种这样的衣服(成套,一系列具体产品),每次拿这种成套的衣服时也自然要从这个衣柜中取出了.用OO的思想去理解,所有的衣柜(具体工厂)都是衣柜类的(抽象工厂)某一个,而每一件成套的衣服又包括具体的上衣(某一具体产品),裤子(某一具体产品),这些具体的上衣其实也都是上衣(抽象产品),具体的裤子也都是裤子(另一个抽象产品).
优点:1当一个产品族中的多个对象被设计成一起工作时,它能保证客户端始终只使用同一个产品族中的对象。
缺点:产品族扩展非常困难,要增加一个系列的某一产品,既要在抽象的Creator里加代码,又要在具体的里面加代码
使用场景:1.QQ换皮肤,一整套一起换 2.生成不同操作系统的程序
注意事项:产品族难扩展,产品等级易扩展
相关文章推荐
- 通过Emulated KMS Servers on non-Windows platforms激活office 2013脚本
- poj 1149 最大流sap
- linux系统下安装flash插件
- 第八章 计时器
- 新浪云平台部署Java代码
- 如何高效利用GitHub
- hdu 4292 最大流拆点建图
- POJ 2947 Widget Factory(高斯消元)
- linux学习二
- Android实现图片轮播切换
- 如何判断机器是大端还是小端
- POJ 2407 Relatives
- hdu 4280 最大流isap
- 由IBM罢工事件再提联想“吃剩饭”策略
- 由IBM罢工事件再提联想“吃剩饭”策略
- java IO流总结2
- 判断一个正整数是否为质数的算法
- hdu 1569 最小点权覆盖(最大流EK)
- SecureCRT连接ubuntu
- CSS相对地址与绝对地址