工厂模式的思考

 

Factory Method模式相对于其他创建型模式,应该是最简单、最容易实现的模式,该模式定义了一个用于创建对象的接口,而让子类决定实例化哪一个类,这样就将实例化的过程延迟到了子类,从而提高了对象创建的灵活性,在这里一个最核心的特征就是为子类提供了一个挂钩。
但是,该模式有一个潜在的缺陷,就是客户可能仅仅为了创建一个特定ConcreteProduct对象而不得不创建Creator的子类,这样,当客户端除了需要一个新的ConcreteProduct而对Creator没有别的新要求时,就会增加维护新产生的Creator类层次负担。通过分析我觉得在如下三个场景中比较适合采用Factory Method模式:
1、Abstract Factory内部。Abstract Factory(抽象工厂)模式可以通过Factory Method实现,此时抽象工厂内的每个创建一类对象的方法就可以是一个Factory Method。结构图如下:
 
2 、框架应用。因为框架给特定应用提供了基础机构,而它(框架)对特定应用的细节是不可知的,所以当在框架中必须创建某种应用对象时,就可以通过工厂方法进行临时填充,具体应用对象的创建通过框架子类重定义该挂钩接口来实现,具体细节描述见该模式的动机部分,结构图如下:
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值