Spring源码中关于抽象方法且是个空实现这样设计的思考

Spring源码抽象方法且空实现设计思想

在Spring源码中onRefresh()就是一个抽象方法且空实现,而refreshBeanFactory()方法就是一个抽象方法。



那么Spring源码中onRefresh方法定义了一个抽象方法且是个空实现,为什么这样设置,好处是什么。为什么不直接将onRefresh设置成抽象方法?

  1. 提供默认行为(空实现)的灵活性

    如果 onRefresh 被直接定义为抽象方法,那么所有继承 AbstractApplicationContext 的子类都必须强制实现这个方法。

    然而,在 Spring 的设计中,并不是所有的子类都需要自定义 onRefresh 的逻辑。例如,某些上下文(如 GenericApplicationContext)可能根本不需要在刷新时执行额外的操作。

    通过提供一个默认的空实现,Spring 避免了强制子类实现该方法的负担,同时允许需要扩展的子类(如 ClassPathXmlApplicationContext 或 FileSystemXmlApplicationContext)根据需要重写它。

  2. 模板方法设计模式

    onRefresh 方法是 Spring 框架中模板方法设计模式的一部分。

    在 AbstractApplicationContext 中,refresh() 方法是一个模板方法,它定义了上下文刷新过程的整体流程,而 onRefresh() 是其中的一个可扩展的钩子方法。

    通过将 onRefresh 定义为空实现,Spring 允许子类在 refresh() 的特定阶段插入自定义逻辑,而无需修改父类的代码。

  3. 避免强制实现,提高代码复用性

    如果 onRefresh 被定义为抽象方法,那么所有继承 AbstractApplicationContext 的子类都必须实现它,即使它们不需要任何额外的逻辑。

    这会导致代码冗余,因为子类可能只是简单地返回或调用父类的其他方法,而不需要实际的实现。

    通过提供空实现,Spring 提高了代码的复用性,并减少了不必要的实现。

  4. 清晰的设计意图

    空实现明确地传达了设计意图:onRefresh 是一个可选的扩展点,子类可以选择性地重写它。

    如果 onRefresh 是抽象方法,开发者可能会误以为它是一个必须实现的核心方法,从而导致误解或不必要的实现。

  5. onRefresh 是一个可选的扩展点,允许子类在上下文刷新过程中插入自定义逻辑。它不是上下文刷新的核心步骤,因此可以提供一个空实现。

    refreshBeanFactory 是上下文刷新的核心步骤之一,负责创建和初始化 BeanFactory。不同的上下文实现需要不同的逻辑来完成这一步骤,因此必须由子类提供具体实现。

相关推荐
无名-CODING11 分钟前
Spring事务管理完全指南:从零到精通(上)
java·数据库·spring
fengxin_rou15 分钟前
【黑马点评实战篇|第一篇:基于Redis实现登录】
java·开发语言·数据库·redis·缓存
数智工坊24 分钟前
【数据结构-栈】3.1栈的顺序存储-链式存储
java·开发语言·数据结构
短剑重铸之日25 分钟前
《设计模式》第七篇:适配器模式
java·后端·设计模式·适配器模式
DFT计算杂谈39 分钟前
VASP+Wannier90 计算位移电流和二次谐波SHG
java·服务器·前端·python·算法
多多*41 分钟前
2月3日面试题整理 字节跳动后端开发相关
android·java·开发语言·网络·jvm·adb·c#
无名的小白1 小时前
openclaw使用nginx反代部署过程 与disconnected (1008): pairing required解决
java·前端·nginx
.ZGR.1 小时前
认识数据结构:图——无人机防空平台的“衍生品”
java·开发语言·数据结构
huidu011 小时前
基于AQS实现的ReentrantLock
java
冰敷逆向1 小时前
京东h5st纯算分析
java·前端·javascript·爬虫·安全·web