spring-beans包源码阅读-3-BeanDefinition

欢迎光临我的个人博客:https://www.jelliclecat.cn/

一. BeanDefinition介绍

第二个我们来说说BeanDefinition,这个接口也是spring的核心接口之一,所有的Bean在实例化之前的各种各样的信息都记录在这个接口的实现类中。

Spring中Bean的配置来源可能很多,比如xml、@Service等注解标注的类、以及硬编码等,这时需要一个统一的类去封装Bean的配置信息,这些信息会指导Bean的初始化行为和指明Bean具有的一些特性。这个封装类就是BeanDefinition。

这个接口的位置在spring-beans模块下的org.springframework.beans.factory.config,可以看到这个接口首先在factory包下,然后在config包下。这个位置也是非常合理的,因为BeanDefinition就是在BeanFactory创建Bean实例的时候,记录这个Bean的各种信息用的,比如说Bean的Class信息、是否是单例、是否懒加载、是否是抽象Bean、有哪些属性、有哪些依赖的其他Bean、initMethod的名称等等。这些信息都是用来初始化Bean的实例的时候使用到的。顾名思义的理解就是对一个Bean的定义。

这个类可以说是BeanFactory的一个辅助类,之后可以看到,BeanFactory的各种工作都是围绕着BeanDefinition进行的,也可以说这两个接口是孪生接口,谁也离不开谁。BeanFactory无疑是spring最核心的接口,在我们正式分析BeanFactory之前,先好好看看与它关系密切的BeanDefinition接口。

二. BeanDefinition实现

spring-beans包源码阅读-3-BeanDefinition_第1张图片
image

GenericBeanDefinition是BeanDefinition的一个实现类,与GenericBeanDefinition平级的类还有RootBeanDefinition和ChildBeanDefinition。spring的Bean有一个特性就是可以继承,一个bean可以指明另一个bean做自己的parent,这里要注意,这种方式指明的继承关系在java虚拟机中并不存在,即,如果使用instanceof等RTTI的方式去检验这两个bean的继承关系是失效的,他们只是逻辑上的继承关系并具有一些继承的特性,比如重写和重写父bean的方法和属性等。

BeanDefinition接口的绝大多数功能都在AbstractBeanDefinition中实现:

  // AbstractBeanDefinition.java
  @Nullable
  private volatile Object beanClass;

  @Nullable
  private String scope = SCOPE_DEFAULT;

  private boolean abstractFlag = false;

  private boolean lazyInit = false;

  private int autowireMode = AUTOWIRE_NO;

  private int dependencyCheck = DEPENDENCY_CHECK_NONE;

  @Nullable
  private String[] dependsOn;

  private boolean autowireCandidate = true;

  private boolean primary = false;

  private final Map qualifiers = new LinkedHashMap<>();

  @Nullable
  private Supplier instanceSupplier;

  private boolean nonPublicAccessAllowed = true;

  private boolean lenientConstructorResolution = true;

  @Nullable
  private String factoryBeanName;

  @Nullable
  private String factoryMethodName;

  @Nullable
  private ConstructorArgumentValues constructorArgumentValues;

  @Nullable
  private MutablePropertyValues propertyValues;

  @Nullable
  private MethodOverrides methodOverrides;

  @Nullable
  private String initMethodName;

  @Nullable
  private String destroyMethodName;

  private boolean enforceInitMethod = true;

  private boolean enforceDestroyMethod = true;

  private boolean synthetic = false;

  private int role = BeanDefinition.ROLE_APPLICATION;

  @Nullable
  private String description;

  @Nullable
  private Resource resource;

没必要一个一个解读了,这些属性的作用可以说一目了然,实现中也没有很复杂的逻辑,知道BeanDefinition的作用之后,我们就可以去看spring的核心BeanFactory了~

当然BeanDefinition的实现类不止文中提到的三种,还有例如对注解支持的实现类和对Configuration类的实现类,但是目的都差不多,都是为了记录一个Bean的各种配置信息。

最后提一嘴这个AttributeAccessor接口,这个接口在Spring中也是无处不在,比如包装一个属性的类PropertyValue类就实现了这个接口。这个接口里面仅仅封装了一个Map,但是其作用是什么我也是不是特别清楚,在调研和学习途中,也比较了"Attribute"这个词和"Property"这两者概念的区别,但是发现google上权威的和非权威的各种解释都有矛盾的地方,甚至在java的官方词库中都没有发现"Attribute"这个词,而只有"Property",AttributeAccessor接口本身的注释也非常的含糊其辞。所以这个地方的合理性我觉得是存疑的,如果有大佬了解这部分内容的,还请您不吝赐教。

Java官方词库:Glossary of Terms

其中对Property的解释如下:

property

Characteristics of an object that users can set, such as the color of a window.

欢迎光临我的个人博客:https://www.jelliclecat.cn/

你可能感兴趣的:(spring-beans包源码阅读-3-BeanDefinition)