首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Spring常用设计模式-抽象工厂模式

抽象工作模式是指提供一个创建一系列相关或相互依赖对象的接口,无需指定他们的具体类。客户端(应用层)不依赖于产品实体类如何被创建、如何被实现等细节,强调的是一系列相关的产品对象(属于同一产品族)一起使用创建对象需要大量重复的代码。需要提供一个产品类的库,所有的产品以同样的接口出现,从而使客户端不依赖于具体实现。

看抽象工厂模式之前,我们要了解两个概念:产品等级结构和产品族。

如上图,一句话解释:一行是一个产品族,一列是一个产品等级(列表)结构,同一族的产品是出自同一个工厂的

通过上图大概能了解一下产品等级结构和产品族,还是以代码举例吧:

第一期简单工厂,第二期工厂方法学校有了第三期优化:每个课程不仅要提供课程的录播视频,还要提供课堂笔记,甚至还要有源码才能构成一个完整的课程。在产品等级中新增两个产品:IVideo录播视频和INode课堂笔记接口。

然后创建一个抽象工厂类CourseFactory:

接下来,创建Java产品族的Java视频类JavaVideo:

扩展产品等级Java课堂笔记类JavaNote:

创建Java产品族的工厂JavaCourseFactory:

然后创建Python产品的Python视频类PythonVideo:

扩展产品等级Python课堂笔记类PythonNote:

然后创建Python产品族的具体工厂PythonCourseFactory:

来看客户端调用:

不是有那么一丝丝感觉了,上面的代码完整的描述了两个产品族Java和python课程,也描述了两个产品恩济视频和笔记。抽象工厂模式完美且清晰的描述了这样一层复杂的关系,但是如果我们再继续扩展产品等级呢,将源码也加入课程,那么我们的代码从抽象工厂到具体工厂全部都要调整,但很显然不符合开闭原则。所以抽象工厂模式也是有缺点的:

(1)规定了所有可能被创建的产品集合,产品族中扩展新的产品困难,需要修改抽象工厂的接口。

(2)增加了系统的抽象性和理解难度。

但在实际应用中,我们千万不能“犯强迫症”甚至有洁癖。实际需求中,产品等级结构升级是一件非常正常的事情。只要不频繁的升级,根据实际情况可以不遵循开闭原则。代码每半年或者一年升级一次有何不可?

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20230111A07CR200?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券