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。不同的上下文实现需要不同的逻辑来完成这一步骤,因此必须由子类提供具体实现。

相关推荐
luming-023 分钟前
报错解决:IDEA终端输出和CMD终端输出Maven版本不一致
java·缓存·bug·intellij-idea
MM_MS6 分钟前
Halcon控制语句
java·大数据·前端·数据库·人工智能·算法·视觉检测
一碗绿豆汤7 分钟前
Java语言概述和开发环境-1
java·开发语言
愈努力俞幸运11 分钟前
rust安装
开发语言·后端·rust
踏浪无痕15 分钟前
JobFlow 负载感知调度:把任务分给最闲的机器
后端·架构·开源
UrbanJazzerati17 分钟前
Python自动化统计工具实战:Python批量分析Salesforce DML操作与错误处理
后端·面试
小画家~21 分钟前
第四十六: channel 高级使用
java·前端·数据库
我爱娃哈哈27 分钟前
SpringBoot + Seata + Nacos:分布式事务落地实战,订单-库存一致性全解析
spring boot·分布式·后端
Li_yizYa34 分钟前
Redis-常见数据类型及应用场景
java·数据库·redis
nil37 分钟前
记录protoc生成代码将optional改成omitepty问题
后端·go·protobuf