设计模式

设计模式核心的核心在于提供了相关问题的解决方案。


创建型设计模式


  抽象工厂
    意图:提供一个创建一系列相关或相互依赖对象的接口,而无须指定它们具体的类。
    适用性:
     一个系统要独立于它的产品的创建、组合和表示
     一个系统要由多个产品系列中的一个来配置时
     要强调一系列相关的产品对象的设计以便进行联合使用时
     提供一个产品类库,只想显示它们的接口而不是实现时
     
  生成器
    意图:将一个复杂的对象的构建与它的表示分离,使得同样的构建过程可以创建不同的表示。
    适用性:
      当创建复杂对象的算法应该独立于该对象的组成部分以及它们的装配方式时。
      当构造过程必须允许被构造的对象有不同的表示时。
      

  工厂方法 
     意图:定义一个用于创建对象的接口,让子类决定实例化哪一个类。使一个类的实例化延迟到其子类。
     适用性:
       当一个类不知道它所必须创建的对象的类的时候。
       当一个类希望由它的子类来指定它所创建的对象的时候。
       当类将创建对象的职责委托给多个帮助子类中的某一个,并且你希望将哪一个帮助子类是代理者这一信息局部化的时候。

  原型
    意图:用原型实例指定创建对象的种类,并且通过复制这些原型创建新的对象。
    适用性:
      当一个系统应该独立于它的产品创建、构成和表示时。
      当要实例化的类是在运行时刻指定时。
      为了避免创建一个产品类层次平行的工厂类层次时。
      当一个类的实例只能有几个不同状态组合中的一种时。建立相应数目的原型并克隆它们,比每次用合适的状态手工实例化该类更方便。

  单例
    意图:保证一个类仅有一个实例,并提供一个访问它的全局访问点。
    适用性:
      当类只能有一个实例而且客户可以从一个众所周知的访问点访问它时。
      当这个唯一实例应该是通过子类化可扩展的,并且客户无须更改代码就能使用一个扩展的实例时。
      

这里写图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 18
    评论
评论 18
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值