设计模式总结

  设计模式的实现并不难,对着例子来,很快就能敲出来。但是,在什么情况下用什么设计模式,这是个问题,最近总结了一下:

设计模式用法
单例保证类的实例只有一个
简单工厂根据参数创建对应具体子类
策略算法、规则的封装、传入具体调用,调用具体算法
装饰者动态对一个对象进行增属性、调用方法等操作,链式操作,随意组合。梳头、画眉、只梳头不画眉、只画眉不梳头
工厂方法创建类,一个实现类要有一个工厂类。总是通过对应的工厂类创建实现类,判断在客户端进行。工厂类太多。
代理对象中保存能执行另一种操作的对象,通过这个保存的对象去操作。
原型用克隆(Clone),代替new对象。克隆的方式能够保留一些同样的信息。
模板方法提炼出相同的公共代码,封装为一个方法模板。
外观通过改造内部实现,让外部看起来调用的方式很简单(如,实际需要调用3个方法,但增加一个方法来调用这3个方法,让外部只调用一个方法即可)。 
建造者 将一个复制对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。
观察者观察者类里面放了一个集合,包含了多个被通知类,被通知类实现一个抽象方法,有一个方法接受通知。 
抽象工厂增加一个接口,让外部依赖接口而不是具体类 
状态多个大致相同的类,只是状态不同,随着不停的调用,一个状态会转为另一个状态(一个类转为另一个类) 
适配器将一个类的接口转换成客户希望的另外一个接口。 可以理解为,仅仅改为一个方法名,在方法内部调用真正的方法(名字不同)。
备忘录增加一个类用于存储状态,一个类负责备份和恢复状态 
组合部分-整体关系,解决无限递归问题。 
迭代器分离了集合对象的遍历行为,抽象出一个迭代器类来负责。解决遍历问题
桥接将继承关系分离出来改为聚合关系 
命令对请求的封装,请求-》真正执行(队列) 
职责链类似于Asp.net管道,一条链操作,每个类都有处理的机会,没权限就往上级抛,直到有权限的类能够处理 
中介者通过一个中介类来处理两个类之间的信息交换
享元对象的大多数状态为外部状态,如果删除对象的外部状态,那么可以用相对较少的共享对象取代很多组对象。
访问者它把数据结构和作用于结构上的操作之间的耦合解脱开(用类封装变化的数据)
解释器用类去封装一条规则

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 
 
分类: 设计模式
 
 
 
+加关注
0
0
 
(请您对文章做出评价)
 
« 上一篇: 应用程序域
» 下一篇: 动态Linq(结合反射)
posted on 2015-09-02 11:51  铭轩同学 阅读( ...) 评论( ...) 编辑 收藏

转载于:https://www.cnblogs.com/mingxuantongxue/p/4778180.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值