Spring 最重要的bean源信息 : BeanDefinition接口相关解释

目录

简介

接口BeanDefinition 简介

接口BeanDefinition 实现类简介

各个实现类的区别/特点

AnnotatedBeanDefinition

AbstractBeanDefinition

ConfigurationClassBeanDefinition

AnnotatedGenericBeanDefinition

ScannedGenericBeanDefinition

合并了的bean定义--MergedBeanDefinition

MergedBeanDefinition的生成

MergedBeanDefinition的应用

总结

演示源码


本文是笔者阅读Spring源码的记录文章,由于本人技术水平有限,在文章中难免出现错误,如有发现,感谢各位指正。很多内容来自别人博客
 

简介

现如今,我们一般获取对象的方式有两种,一种是手动直接 new;另一种是交给 Spring 管理,Spring 将管理的对象称之为 Bean,容器会先实例化 Bean,然后自动注入,实例化的过程就需要依赖 BeanDefinition

对于基于Spring框架开发的一个应用系统,其中每一个bean都来自于一个bean定义:开发人员的某个bean定义,框架自身的某个bean定义,三方库的某个bean定义。

这些概念上的bean定义,通过Spring接口BeanDefinition被建模,并且在应用运行时都会以一个BeanDefinition对象的形式被注册到Spring IoC容器中。所以说,bean定义,或者说,BeanDefinition接口,是整个Spring容器的根本概念之一。

BeanDefinition 用于保存 Bean 的相关信息,包括属性、构造方法参数、依赖的 Bean 名称及是否单例、延迟加载等,它是实例化 Bean 的原材料,Spring 就是根据 BeanDefinition 中的信息实例化 Bean

接口BeanDefinition 简介

Spring框架中的接口BeanDefinition顾名思义,就是"bean定义"的意思,它定义了创建相应的bean 使用如下属性 :

属性名称 介绍
parentName 双亲bean定义(parent bean definition)的名称.如果没有双亲bean定义,这里为空
beanClassName bean的类名,在bean factorypost process阶段可能会被修改。注意该属性并不总是运行时被对应bean真正使用的类的名称:比如,bean是通过某个类的静态工厂方法生成的,这里是该类的类名,再比如,bean是通过一个工厂bean生成的,那这里为空。
scope 作用域, singleton或者prototype。在bean的作用域尚未决定之前,该属性为null
lazyInit 是否懒加载,仅适用于singleton bean。当一个singleton bean被指定lazyInitfalse时,它会在bean factory启动时执行singleton bean初始化的阶段被实例化。
dependsOn 所依赖的bean的名称,如果有多个依赖的bean,这里需要都列出来。容器会保证这些被依赖的bean先被初始化。
autowireCandidate bean是否作为自动绑定的候选,仅适用于基于类型的自动绑定。基于名称的绑定不受此属性影响。
primary 当前bean定义是否主bean。当某个自动绑定遇到多个候选bean时,primary属性为true的会被使用。
factoryBeanName 如果要使用factory bean来创建bean,这里指定了相应的工厂bean的类名称
factoryMethodName 工厂方法名称。基于类静态工厂方法的情况下,结合beanClassName使用;基于工厂bean的情况下,结合factoryBeanName使用。如果bean定义的constructorArgumentValues有内容,工厂方法被调用时会使用该属性。
constructorArgumentValues bean创建时的构造函数参数
propertyValues 新建的bean需要设置的属性值
initMethodName bean的初始化方法
destroyMethodName bean的析构方法
role bean的角色:APPLICATION,SUPPORT,INFRASTRUCTURE。提示框架该bean的角色和重要程度。
description bean的描述,human readable
singleton 作用域断言,是否singleton
prototype 作用域断言,是否prototype
abstract 是否抽象bean定义,抽象bean定义的目的不是用于实例化bean,而是有其他目的。
resourceDescription 资源描述文本,告知当前bean定义的来源,一般用于错误时显示上下文。
originatingBeanDefinition 返回来源bean定义(如果有的话)。通过该属性,可以获取被修饰的bean定义。需要注意的是该属性仅仅返回直接来源bean定义而不是返回最深处的来源bean定义。一个bean定义的originatingBeanDefinition属性隐含了一个来源bean定义链,通过迭代访问该链,可以最终找到最终来自用户的bean定义。

上表中提到的bean的角色,分别是:

  • APPLICATION – 指出该bean是应用程序的主要部分,通常对应用户定义的bean。
  • SUPPORT – 应用支持性质的bean,在某些地方比较重要,但从整个应用的返回来看,还没那么重要。
  • INFRASTRUCTURE – 基础设施bean,仅仅用于框架内部工作,跟终端用户无关。

接口BeanDefinition 实现类简介

BeanDefinition 接口有一些实现类,并且这些实现类有一些共同的基础逻辑。这些实现类主要是 : RootBeanDefinition,ChildBeanDefinition和GenericBeanDefinition。它们共同的基础逻辑实现在抽象类AbstractBeanDefinition。这些类之间的层级关系如下:
BeanDefinition.png

根据类图看到BeanDefinition有GenericBeanDefinitionChildBeanDefinitionRootBeanDefinition三个实现类;

BeanDefinition是配置文件<bean>元素标签在容器中内部表示形式。

  • RootBeanDefinition可以单独作为一个BeanDefinition,也可以作为其他BeanDefinition的父类。但是他不能作为其他BeanDefinition的子类
  • ChildBeanDefinition相当于一个子类,不可以单独存在,必须要依赖一个父BeanDetintion
  • GenericBeanDefinition 可以替代RootBeanDefinitionChildBeanDefinition
  • AnnotatedGenericBeanDefinition处理@Configuration注解
  • ConfigurationClassBeanDefinition处理@Bean注解
  • ScannedGenericBeanDefinition处理@Component注解

一般情况下,建议使用GenericBeanDefinition用于定义用户可见的bean

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值