标签:eth 原型 分享 alt 细节 装饰者 http 可扩展 dap
确保一个类只有一个实例,并提供一个全局访问点
优点:
缺点:
定义一个用于创建对象的接口,让子类决定实例化哪个类,工厂方法使一个类的实例化延迟其子类
提供了一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体类。
优点:
抽象工厂模式将具体产品的创建延迟到具体工厂的子类中,这样将对象的创建封装起来,可以减少客户端与具体产品类之间的依赖,从而使系统耦合低。这样更有利于后期的维护发展
缺点:
抽象工厂模式很难支持新种类产品的变化,这是因为抽象工厂接口中已经确定了可以被创建的产品集合,如果需要添加新产品,此时就必须修改抽象工厂的接口,这样涉及到抽象工厂类的以及所有子类的改变,这样违背了“开发---关闭”原则。
将一个复杂对象的构建与它的表示分离,使用同样的构造过程可以构建不同的表示
建造模型要点
用原型实例指定创建对象的种类,并且通过拷贝这些原型创建新对象
优点:
缺点:
将一个类接口转化成客户希望的另外一个接口,Adapter模式使得原来由于接口不兼容而无法一起工作的类可以一起工作
适配器模式分为类适配器模式和对象适配器模式
类适配器模式
优点:
1.可以在不修改原有代码的基础上来复用现有类,很好的符合“开闭原则”
2.可以重新定义Adaptee(被适配的类)的部分行为,因为在类适配器模式中,Adapter是Adaptee的子类
3.仅仅引用一个对象,并不需要额外的字段来引用Adapter实例(这个既是优点也是缺点)
缺点:
1.用一个具体的Adapter类对Adaptee和Target进行匹配,当如果想要匹配一个类以及所有它的子类时,类的适配器模式就不能胜任了,因为类的适配器模式中没有引用Adaptee的实例,光调用this.SpecificRequest方法并不能去调用它的对应子类的SpecificRequest方法
2.采用了“多继承”的实现方式,带来了不良的高耦合
对象适配器
优点:
1.可以在不修改原有代码的基础上来复用现有类,很好的符合“开闭原则”。
2.采用了“对象组合”方式,更符合松耦合
缺点:
1.使得重定义Adaptee的行为较困难,这需要生成Adaptee的子类并且使得Adaptee引用这个子类而不是引用Adaptee本身
适配器模式使用场景
1.系统需要复用现有类,而该类的接口不符合系统的需求
2.想要建立一个可重复使用的类,用于与一些彼此之间没有太大关系的一些类,包括一些可能在将来引进的类一起工作
3.对于对象适配器模式,在设计里需要改变多个已有子类的接口,如果使用类的适配器,就要针对每一个子类做一个适配器,而这不太实际。
将实现与抽象放在两个不同的类中,使两个层次可以独立改变.桥接模式强调了接口对象提供的是一种算法
优点:
1.抽象与实现与其实现解耦
2.抽象和实现可以独立扩展,不会影响到对方
3.实现细节对客户透明,对用于隐藏了具体的细节
缺点:
增加了系统的复杂度
使用场景:
1.如果一个系统需要在构建的抽象化角色和具体化角色之间添加更多的灵活性,避免在两个层次之间建立静态的联系
2.设计要求实现化角色的任何改变不应当影响客户端,或者实现化角色的改变对客户端是完全透明的
3.需要跨越多个平台的图形和窗口系统上
4.一个类存在两个独立变化的维度,且两个维度都需要进行扩展。
动态的给一个对象添加一些额外的职责,就添加功能来说,装饰者模式比生成子类更加灵活
优点:
1.装饰者模式和继承的目的都是扩展对象的功能,但装饰者模式比继承更加灵活
2.通过使用不同的具体装饰类以及这些类的排列组合,设计师可以创造出很多不同行为的组合
3.装饰者模式有很好的可扩展性
缺点:
装饰者模式会导致设计中出现许多小对象,如果过度使用,会让程序变得更复杂,并且更多的对象会是的差错变得困难,特别是这些对象看起来很像。
使用场景:
1.需要扩展一个类的功能或给一个类附加责任
2.需要动态的给一个对象增加功能,这些功能可以在动态的撤销
3.需要增加由一些基本功能的排列组合而产生的大量的功能
标签:eth 原型 分享 alt 细节 装饰者 http 可扩展 dap
原文地址:http://www.cnblogs.com/yan7/p/7911815.html