博客
关于我
Spring BeanFactory 详解
阅读量:586 次
发布时间:2019-03-09

本文共 1680 字,大约阅读时间需要 5 分钟。

BeanFactory 介绍

BeanFactory 是 Spring 应用程序的核心配置管理和对象创建中心。它作为 bean 容器的客户端接口,负责加载和管理 application components。任何依赖注入的操作都通过 BeanFactory实现,比如通过构造函数或 setter 方法注入。如果采用 lazy loading,则可以控制资源的初始化时机。

BeanFactory 的主要作用包括:

  • 作为中央配置管理平台,集中管理应用程序的 components 和配置;
  • 支持多种 bean 定义方式,如 XML、属性文件、数据库等;
  • 根据配置确定每个 bean 的实例类型(Singleton 或 Prototype)。
  • 与传统的工厂模式相比,BeanFactory 提供了更高的灵活性。通过 centralized配置,开发者无需在每个类中显式读取配置文件,简化了代码管理。但要正确 使用 BeanFactory,建议采用依赖注入机制(push configuration),而不是通过查找(pull configuration)。

    BeanFactory 的工作流程

  • 通过读取配置文件(如 XML)或其他数据源,解析 bean 定义;
  • 根据 bean 的定义,创建相应的实例,具体实例数取决于配置:
    • 若标记为 Singleton,则返回唯一实例;
    • 若标记为 Prototype,则每次请求获取新实例(通过 lazy loading)。
  • 支持父工厂继承机制,如果当前工厂未找到 bean,会询问父工厂,此外也应注意 bean 的定义顺序。
  • Bean 的生命周期管理包括初始化方法调用和销毁操作。初始化顺序遵循标准接口的定义:
    • priority关系:BeanNameAware → BeanClassLoaderAware → BeanFactoryAware → EnvironmentAware → ... →customize方法。
    • 销毁过程则遵循 DestructionAwareBeanPostProcessor 的机制。
  • BeanFactory 实现要点

  • 依赖注入:通过 setter 或 constructor 注入 values 或 resources,BeanFactory支持各种 aware 接口,如 EnvironmentAware、ResourceLoaderAware 等。依赖注入是优化配置管理的核心方式。
  • 灵活的 bean 定义方式:支持多种数据源,如 LDAP、RDBMS、XML 或 properties 文件等。不同的实现可根据具体需求选择。
  • 面向接口设计:BeanFactory 接口定义了标准的 getBean 方法,允许实现灵活扩展。例如,ListableBeanFactory 提供按类型查找的功能。
  • 安全性管理:BeanFactory 需要管理 own instance 是否已经加载,以防止重复加载或多个线程同时访问导致的问题。
  • BeanFactory 的注意事项

    • 避免.getBean() 超频:如果频繁调用 getBean 可能导致性能问题,应使用 Provider 或 ResolvableType 加载懒惰实例。
    • ** Coneurrency Handling **:确保在多线程环境中正确管理 bean 实例。
    • ** Graceful Shutdown **:在关闭 BeanFactory 时,确保调用 destruction 方法,释放资源并调用 postProcessors。

    BeanFactory 的类图示略

    (此处应放置 BeanFactory 的类图,但因图片链接已移除,故此处用文字表示)

    BeanFactory 接口是核心,而其实现类(如 DefaultBeanFactory)则负责具体实现各种功能模块。

    通过上述介绍,BeanFactory 已经成为理解 Spring 内部工作机制的基础知识。希望本文能帮助开发者更好地掌握 Spring 的核心容器管理机制。

    转载地址:http://usdpz.baihongyu.com/

    你可能感兴趣的文章
    Nginx配置ssl实现https
    查看>>
    Nginx配置TCP代理指南
    查看>>
    Nginx配置——不记录指定文件类型日志
    查看>>
    Nginx配置代理解决本地html进行ajax请求接口跨域问题
    查看>>
    Nginx配置参数中文说明
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    NHibernate学习[1]
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>