Spring高手之路11——BeanDefinition解密:构建和管理Spring Beans的基石

这篇具有很好参考价值的文章主要介绍了Spring高手之路11——BeanDefinition解密:构建和管理Spring Beans的基石。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

  BeanDefinitionSpring中一个非常重要的概念,它包含了Spring容器用于创建、配置Bean所需的所有信息。理解BeanDefinition可以帮助我们深入掌握Spring的内部工作机制。

1. 探索BeanDefinition

首先,让我们来对 BeanDefinition 有一个整体的认识。

1.1 官方文档对BeanDefinition的解读

  对于理解Spring框架的概念和组件,Spring的官方文档是一个非常重要的资源。关于BeanDefinition,官方文档大意如下:

  BeanDefinition包含了大量的配置信息,这些信息可以指导Spring如何创建Bean,包括Bean的构造函数参数,属性值,初始化方法,静态工厂方法名称等等。此外,子BeanDefinition还可以从父BeanDefinition中继承配置信息,同时也可以覆盖或添加新的配置信息。这种设计模式有效减少了冗余的配置信息,使配置更为简洁。

接下来,让我们通过一个具体的例子来更好地理解BeanDefinition

考虑一个简单的Java类,Person

public class Person {
    private String name;
    private int age;

    public Person() {}

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    // getters and setters
}

我们可以用XML配置或者Java配置的方式来定义一个Person类型的Bean,同时这个Bean的配置信息会被封装在BeanDefinition中。

XML配置中,一个Person Bean的定义可能如下:

<bean id="person" class="com.example.Person">
    <constructor-arg name="name" value="John"/>
    <constructor-arg name="age" value="25"/>
</bean>

在这里,BeanDefinition的信息包括了class属性(全限定类名)以及构造函数参数的名称和值。

Java配置中,我们可以这样定义一个Person Bean

@Configuration
public class AppConfig {
    @Bean
    public Person person() {
        return new Person("John", 25);
    }
}

  在这个例子中,BeanDefinition的信息包括class属性(全限定类名)以及构造函数参数。我们可以通过BeanDefinitiongetBeanClassName()方法获取到这个全限定类名。

1.2 BeanDefinition关键方法剖析

BeanDefinition接口定义了Bean的所有元信息,主要包含以下方法:

  • get/setBeanClassName() - 获取/设置Bean的类名
  • get/setScope() - 获取/设置Bean的作用域
  • isSingleton() / isPrototype() - 判断是否单例/原型作用域
  • get/setInitMethodName() - 获取/设置初始化方法名
  • get/setDestroyMethodName() - 获取/设置销毁方法名
  • get/setLazyInit() - 获取/设置是否延迟初始化
  • get/setDependsOn() - 获取/设置依赖的Bean
  • get/setPropertyValues() - 获取/设置属性值
  • get/setAutowireCandidate() - 获取/设置是否可以自动装配
  • get/setPrimary() - 获取/设置是否首选的自动装配Bean

  由于BeanDefinition源码篇幅较长,这里就不全部贴上来,大家可以自行查看。BeanDefinition还实现了AttributeAccessor接口,可以通过该接口添加自定义元数据,后面小节会举例AttributeAccessor的使用。

  从上面可以看到,BeanDefinitionSpring 框架中用来描述 Bean 的元数据对象,这个元数据包含了关于 Bean 的一些基本信息,包括以下几个方面:

  • Bean 的类信息: 这是 Bean 的全限定类名,即这个 Bean 实例化后的具体类型。

  • Bean 的属性信息: 包括了如 Bean 的作用域(是单例还是原型)、是否为主要的 Beanprimary)、描述信息等。

  • Bean 的行为特性: 例如 Bean 是否支持延迟加载,是否可以作为自动装配的候选者,以及 Bean 的初始化和销毁方法等。

  • Bean 与其他 Bean 的关系: 比如说这个 Bean 所依赖的其他 Bean,以及这个 Bean 是否有父 Bean

  • Bean 的配置信息: 这包括了 Bean 的构造器参数,以及属性值等。

1.3 BeanDefinition部分方法的实际运用

  接下来用一个详细的代码示例来说明BeanDefinition接口中各个方法的使用,并结合实际的代码示例说明这些方法的实际含义。下面,我会针对BeanDefinition的几个重要方面提供代码示例。

全部代码如下:

首先,这是我们的Java配置类以及Person类的定义:

package com.example.demo.configuration;

import com.example.demo.bean.Person;
import org.springframework.context.annotation.*;

@Configuration
public class AppConfig {

    @Bean(initMethod = "init", destroyMethod = "cleanup")
    @Scope("singleton")
    @Lazy
    @Primary
    @Description("A bean for person")
    public Person person() {
        return new Person("John", 25);
    }
}
package com.example.demo.bean;

public class Person {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    // getters and setters

    public void init() {
        System.out.println("Initializing Person bean");
    }

    public void cleanup() {
        System.out.println("Cleaning up Person bean");
    }
}

下面是如何通过BeanDefinition获取到各个属性:

package com.example.demo;

import com.example.demo.configuration.AppConfig;
import org.springframework.beans.factory.config.BeanDefinition;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;

import java.util.Arrays;

public class DemoApplication {
    public static void main(String[] args) {
        AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(AppConfig.class);
        String personBeanName = "person";
        BeanDefinition personBeanDefinition = context.getBeanFactory().getBeanDefinition(personBeanName);

        // 获取Bean的类信息
        System.out.println("Bean Class Name: " + context.getBean(personBeanName).getClass().getName());

        // 获取Bean的属性
        System.out.println("Scope: " + personBeanDefinition.getScope());
        System.out.println("Is primary: " + personBeanDefinition.isPrimary());
        System.out.println("Description: " + personBeanDefinition.getDescription());

        // 获取Bean的行为特征
        System.out.println("Is lazy init: " + personBeanDefinition.isLazyInit());
        System.out.println("Init method: " + personBeanDefinition.getInitMethodName());
        System.out.println("Destroy method: " + personBeanDefinition.getDestroyMethodName());

        // 获取Bean的关系
        System.out.println("Parent bean name: " + personBeanDefinition.getParentName());
        System.out.println("Depends on: " + Arrays.toString(personBeanDefinition.getDependsOn()));

        // 获取Bean的配置属性
        System.out.println("Constructor argument values: " + personBeanDefinition.getConstructorArgumentValues());
        System.out.println("Property values: " + personBeanDefinition.getPropertyValues());
    }
}

运行结果:

beandefinition,Spring高手之路,BeanDefinition,Spring框架,IoC容器,元信息,Bean配置,原力计划

  这个例子包含了BeanDefinition的大部分方法,展示了它们的作用。请注意,在这个例子中,一些方法如getDependsOn()getParentName()getConstructorArgumentValues()getPropertyValues()的返回结果可能不会显示出任何实质内容,因为我们的person Bean并没有设置这些值。如果在实际应用中设置了这些值,那么这些方法将返回相应的结果。

1.4 BeanDefinition深层信息结构梳理

Spring 中,BeanDefinition 包含了以下主要信息:

  • Class:这是全限定类名,Spring 使用这个信息通过反射创建 Bean 实例。例如,com.example.demo.bean.Book,当 Spring 需要创建 Book bean 的实例时,它将根据这个类名通过反射创建 Book 类的实例。

  • Name:这是 Bean 的名称。在应用程序中,我们通常使用这个名称来获取 Bean 的实例。例如,我们可能有一个名称为 "bookService"Bean,我们可以通过 context.getBean("bookService") 来获取这个 Bean 的实例。

  • Scope:这定义了 Bean 的作用域,例如 singletonprototype。如果 scopesingleton,那么 Spring 容器将只创建一个 Bean 实例并在每次请求时返回这个实例。如果 scopeprototype,那么每次请求 Bean 时,Spring 容器都将创建一个新的 Bean 实例。

  • Constructor arguments:这是用于实例化 Bean 的构造函数参数。例如,如果我们有一个 Book 类,它的构造函数需要一个 String 类型的参数 title,那么我们可以在 BeanDefinition 中设置 constructor arguments 来提供这个参数。

  • Properties:这些是需要注入到 Bean 的属性值。例如,我们可能有一个 Book 类,它有一个 title 属性,我们可以在 BeanDefinition 中设置 properties 来提供这个属性的值。这些值也可以通过 <property> 标签或 @Value 注解在配置文件或类中注入。

  • Autowiring Mode:这是自动装配的模式。如果设置为 byType,那么 Spring 容器将自动装配 Bean 的属性,它将查找容器中与属性类型相匹配的 Bean 并注入。如果设置为 byName,那么容器将查找容器中名称与属性名相匹配的 Bean 并注入。还有一个选项是 constructor,它指的是通过 Bean 构造函数的参数类型来自动装配依赖。

  • Lazy Initialization:如果设置为 trueBean 将在首次请求时创建,而不是在应用启动时。这可以提高应用的启动速度,但可能会在首次请求 Bean 时引入一些延迟。

  • Initialization Method and Destroy Method:这些是 Bean 的初始化和销毁方法。例如,我们可能有一个 BookService 类,它有一个名为 init 的初始化方法和一个名为 cleanup 的销毁方法,我们可以在 BeanDefinition 中设置这两个方法,那么 Spring 容器将在创建 Bean 后调用 init 方法,而在销毁 Bean 之前调用 cleanup 方法。

  • Dependency beans:这些是 Bean 的依赖关系。例如,我们可能有一个 BookService Bean,它依赖于一个 BookRepository Bean,那么我们可以在 BookServiceBeanDefinition 中设置 dependency beans"bookRepository",那么在创建 BookService Bean 之前,Spring 容器将首先创建 BookRepository Bean

  以上就是 BeanDefinition 中主要包含的信息,这些信息将会告诉 Spring 容器如何创建和配置 Bean。不同的 BeanDefinition 实现可能会有更多的配置信息。例如,RootBeanDefinitionChildBeanDefinitionGenericBeanDefinition 等都是 BeanDefinition 接口的具体实现类,它们可能包含更多的配置选项。

2. BeanDefinition构造体系解析

  让我们首先明确BeanDefinition的角色。BeanDefinitionSpring中的核心组件,它定义了bean的配置信息,包括类名、作用域、构造器参数、属性值等。下面我们来看看BeanDefinitionSpring中的设计是如何的。

通过IDEA我们可以得到如下的继承关系图:

beandefinition,Spring高手之路,BeanDefinition,Spring框架,IoC容器,元信息,Bean配置,原力计划

虽然有许多接口、抽象类和扩展,我们只需要关注其中的关键部分。

2.1 BeanDefinition的类型及其应用

Spring中,一个bean的配置信息就是由BeanDefinition对象来保存的。根据bean配置的不同来源和方式,BeanDefinition又被分为很多种类型,我们选取其中几种讲解一下

  • RootBeanDefinition:当我们在XML配置文件中定义一个bean时,Spring会为这个bean创建一个RootBeanDefinition对象,这个对象包含了所有用于创建bean的信息,如bean的类名、属性值等。例如:
<bean id="exampleBean" class="com.example.ExampleBean">
    <property name="stringProperty" value="stringValue"/>
</bean>

  这段XML配置中定义了一个名为"exampleBean"bean,它的类是"com.example.ExampleBean",并且有一个名为"stringProperty"的属性值是"stringValue"。当Spring读取这段配置时,会创建一个RootBeanDefinition对象来保存这个bean的所有配置信息。

  总结:在XML文件中定义一个bean时,Spring就会创建一个RootBeanDefinition实例,这个实例会保存所有的配置信息,比如类名、属性值等。

  • ChildBeanDefinition:当我们需要让一个bean继承另一个bean的配置时,可以使用ChildBeanDefinition。例如:
<bean id="parentBean" class="com.example.ParentBean">
    <property name="stringProperty" value="stringValue"/>
</bean>

<bean id="childBean" parent="parentBean">
    <property name="anotherStringProperty" value="anotherStringValue"/>
</bean>

  这段XML配置中,"childBean"继承了"parentBean"的所有配置,同时还添加了一个新的属性"anotherStringProperty"。当Spring读取这段配置时,会首先为"parentBean"创建一个RootBeanDefinition对象,然后为"childBean"创建一个ChildBeanDefinition对象,这个对象会引用"parentBean"BeanDefinition

  总结:如果有一个bean,并且想创建一个新的bean,这个新的bean需要继承原有bean的所有配置,但又要添加或修改一些配置信息,Spring就会创建一个ChildBeanDefinition实例。

  • GenericBeanDefinition:这是一种通用的BeanDefinition,可以根据需要转化为RootBeanDefinition或者ChildBeanDefinition。例如,在一个配置类中使用@Bean注解定义了一个bean
@Configuration
public class AppConfig {
    @Bean
    public MyComponent myComponent() {
        return new MyComponent();
    }
}

  在这段代码中,我们定义了一个名为"myComponent"bean,它的类是"MyComponent"。当Spring解析这个配置类时,会为myComponent()方法创建一个GenericBeanDefinition对象。这个GenericBeanDefinition对象会保存方法的名字(这也是bean的名字)、返回类型,以及任何需要的构造函数参数或属性。在这个例子中,我们没有定义任何参数或属性,所以GenericBeanDefinition对象只包含了基本的信息。这个GenericBeanDefinition对象之后可以被Spring容器用于生成bean的实例。

  总结:在Java配置类中使用@Bean注解定义一个bean时,Spring就会创建一个GenericBeanDefinition实例。

  • AnnotatedBeanDefinition:当我们在代码中使用注解(如@Component, @Service, @Repository等)来定义bean时,Spring会创建一个AnnotatedBeanDefinition接口的实例。例如:
@Component("myComponent")
public class MyComponent {
    // some fields and methods
}

  在这段代码中,我们定义了一个名为"myComponent"bean,它的类是"MyComponent",并且这个类上有一个@Component注解。当Spring解析这个类时,会创建一个AnnotatedBeanDefinition对象。这个AnnotatedBeanDefinition对象会保存类名(这也是bean的名字)、类的类型,以及类上的所有注解信息。在这个例子中,AnnotatedBeanDefinition实例会包含@Component注解及其所有元数据。这个AnnotatedBeanDefinition实例之后可以被Spring容器用于生成bean的实例,同时Spring还可以使用存储在AnnotatedBeanDefinition中的注解信息来进行进一步的处理,如AOP代理、事务管理等。

  总结:在类上使用注解(如@Component, @Service, @Repository等)来定义一个bean时,Spring会创建一个实现了AnnotatedBeanDefinition接口的实例,如AnnotatedGenericBeanDefinitionScannedGenericBeanDefinition。这个实例会保存类名、类的类型,以及类上的所有注解信息。

  GenericBeanDefinitionAnnotatedBeanDefinition的主要区别在于,AnnotatedBeanDefinition保存了类上的注解信息,而GenericBeanDefinition没有。这就使得Spring能够在运行时读取和处理这些注解,提供更丰富的功能。

  在大多数情况下,我们并不需要关心Springbean创建的是哪一种BeanDefinitionSpring会自动管理这些BeanDefinition,并根据它们的类型以及它们所包含的信息来创建和配置bean

2.2 生成BeanDefinition的原理剖析

  这个 BeanDefinition 对象是在 Spring 启动过程中由各种 BeanDefinitionReader 实现类读取配置并生成的。

  在 Spring 中主要有三种方式来创建 BeanDefinition

  • XML 配置方式

首先,我们在 XML 文件中定义了一个 bean

<bean id="bookService" class="com.example.demo.service.BookService">
    <property name="bookRepository" ref="bookRepository"/>
</bean>

<bean id="bookRepository" class="com.example.demo.repository.BookRepository"/>

  在这种情况下,当 Spring 启动的时候,XmlBeanDefinitionReader 会读取这个 XML 文件,解析其中的 <bean> 元素,并为每一个 <bean> 元素创建一个 BeanDefinition 对象。

简单描述为:由XmlBeanDefinitionReader读取XML文件,解析<bean>元素并生成BeanDefinition

  • 注解配置方式

我们在类上使用 @Component, @Service, @Repository 等注解来定义 bean,例如:

@Repository
public class BookRepository {
    // ... repository methods
}

@Service
public class BookService {
    private final BookRepository bookRepository;
    
    public BookService(BookRepository bookRepository) {
        this.bookRepository = bookRepository;
    }
    
    // ... service methods
}

  在这种情况下,当 Spring 启动的时候,ClassPathBeanDefinitionScanner 会扫描指定的包路径,找到所有带有特定注解的类,并为这些类创建 BeanDefinition 对象。这种方式下生成的 BeanDefinition 通常是 ScannedGenericBeanDefinition 类型。

  简单描述为:由ClassPathBeanDefinitionScanner扫描指定包路径下的带注解的类,并生成BeanDefinition

  • Java 配置方式

我们使用 @Configuration@Bean 注解来定义配置类和 bean,例如:

@Configuration
public class AppConfig {

    @Bean
    public BookRepository bookRepository() {
        return new BookRepository();
    }

    @Bean
    public BookService bookService(BookRepository bookRepository) {
        return new BookService(bookRepository);
    }
}

  在这种情况下,当 Spring 启动的时候,ConfigurationClassPostProcessor 就会处理这些配置类,并交给 ConfigurationClassParser 来解析。对于配置类中每一个标记了 @Bean 的方法,都会创建一个 BeanDefinition 对象。这种方式下生成的 BeanDefinition 通常是 ConfigurationClassBeanDefinition 类型。

  简单描述为:由ConfigurationClassPostProcessor处理标记了@Configuration的类,解析其中的@Bean方法并生成BeanDefinition

  总的来说,不论我们选择 XML 配置、注解配置还是 Java 配置方式,Spring 启动时都会解析这些配置,并生成对应的 BeanDefinition 对象,以此来指导 Spring 容器如何创建和管理 Bean 实例。

  这些内容可能比较抽象和复杂,但对于初学者来说,只需要理解:BeanDefinitionSpring 用来存储 Bean 配置信息的对象,它是在 Spring 启动过程中由 BeanDefinitionReader 读取配置生成的,具体的生成方式取决于使用的配置方式(XML、注解或者 Java 配置),至于其中具体的实现原理,以后再深入了解。

2.3 AttributeAccessor实战:属性操作利器

  AttributeAccessorSpring框架中的一个重要接口,它提供了一种灵活的方式来附加额外的元数据到Spring的核心组件。在Spring中,包括BeanDefinition在内的许多重要类都实现了AttributeAccessor接口,这样就可以动态地添加和获取这些组件的额外属性。这样做的一个显著好处是,开发人员可以在不改变原有类定义的情况下,灵活地管理这些组件的额外信息。

让我们来看一个例子,全部代码如下:

先创建一个Book对象

class Book {
    private String title;
    private String author;

    public Book() {}

    public Book(String title, String author) {
        this.title = title;
        this.author = author;
    }

    // getter 和 setter 省略...
}

主程序:

package com.example.demo;

import com.example.demo.bean.Book;
import org.springframework.beans.factory.config.BeanDefinition;
import org.springframework.beans.factory.support.RootBeanDefinition;

public class DemoApplication {

    public static void main(String[] args) {
        // 创建一个BeanDefinition, BeanDefinition是AttributeAccessor的子接口
        BeanDefinition bd = new RootBeanDefinition(Book.class);

        // 设置属性
        bd.setAttribute("bookAttr", "a value");

        // 检查和获取属性
        if(bd.hasAttribute("bookAttr")) {
            System.out.println("bookAttr: " + bd.getAttribute("bookAttr"));

            // 移除属性
            bd.removeAttribute("bookAttr");
            System.out.println("bookAttr: " + bd.getAttribute("bookAttr"));
        }
    }
}

  在这个例子中,我们创建了一个RootBeanDefinition实例来描述如何创建一个Book类的实例。RootBeanDefinitionBeanDefinition的实现,而BeanDefinition实现了AttributeAccessor接口,因此RootBeanDefinition也就继承了AttributeAccessor的方法。

有人可能会疑问,Book并没有bookAttr这个成员变量,这是怎么赋值的?

  在Spring框架中,AttributeAccessor接口定义的方法是为了附加、获取和移除与某个对象(例如RootBeanDefinition)相关联的元数据,而不是操作对象(例如Book)本身的字段。

  所以,在RootBeanDefinition实例上调用setAttribute("bookAttr", "a value")方法时,其实并不是在Book实例上设置一个名为bookAttr的字段。而是在RootBeanDefinition实例上附加了一个元数据,元数据的键是"bookAttr",值是"a value"

  后续使用getAttribute("bookAttr")方法时,它将返回之前设置的元数据值"a value",而不是尝试访问Book类的bookAttr字段(实际上Book类并没有bookAttr字段)。

  简单来说,这些元数据是附加在RootBeanDefinition对象上的,而不是附加在由RootBeanDefinition对象描述的Book实例上的。

运行结果:

beandefinition,Spring高手之路,BeanDefinition,Spring框架,IoC容器,元信息,Bean配置,原力计划

总结:

  BeanDefinition是实现了AttributeAccessor接口的一个重要的类,BeanDefinition 对象是 Spring 框架用来存储 bean 配置信息的数据结构。当我们在配置类中使用 @Bean@Scope@Lazy 等注解定义一个 bean 时,Spring 会为这个 bean 创建一个 BeanDefinition 对象,并将这些注解的元数据附加到这个 BeanDefinition 对象上。

  当 Spring 容器在后续需要创建 bean实例时,它会查看这个 BeanDefinition 对象,按照其中的元数据(如 scopelazy 初始化、初始化和销毁方法等)来创建和管理 bean实例。这些元数据并不会直接附加到 bean实例上,而是存储在 BeanDefinition 对象中,由 Spring 容器来管理和使用。

  所以,当我们在 main 方法中从 ApplicationContext 获取 BeanDefinition 并打印其属性时,我们实际上是在查看 Spring 框架用来管理 bean 的内部数据结构,而不是直接查看 bean 实例本身的状态。

  这种方法的好处是,它将这些额外的元数据与bean实例本身分离,这样就可以在不修改bean类的情况下灵活地改变这些元数据,而且AttributeAccessor可以在同一个JVM进程中的不同线程间共享数据。这也是为什么我们可以通过修改配置文件或注解来改变bean的范围、是否是懒加载等,而不需要修改bean的类定义。

3. BeanDefinition回顾及总结

  在我们深入探讨Spring框架的过程中,我们已经了解了BeanDefinitionSpring中非常关键的一个概念。BeanDefinition的主要职责是作为一个数据对象,存储了关于如何创建、初始化、配置一个具体的Bean实例的详细信息。

特别是,BeanDefinition中包含以下主要信息:

  • 完全限定的类名,以便Spring容器通过反射创建Bean实例。
  • Bean的名称和别名,用于在应用中引用和查找Bean
  • Bean的作用域,如单例或原型,决定了Spring如何管理Bean实例的生命周期。
  • 构造函数参数和属性值,用于实例化Bean和依赖注入。
  • 自动装配模式,指示Spring如何自动注入依赖。
  • 初始化和销毁方法,让Spring知道在Bean生命周期的特定时刻如何执行自定义逻辑。
  • Bean的依赖关系,告诉Spring在创建当前Bean之前需要先创建哪些Bean

  无论我们使用哪种配置方式(XML、注解或Java配置),Spring在启动时都会解析这些配置,然后生成相应的BeanDefinition对象。这些BeanDefinition对象就像是Spring容器内部的配方,告诉Spring容器如何创建和配置各个Bean文章来源地址https://www.toymoban.com/news/detail-612536.html


欢迎一键三连~

有问题请留言,大家一起探讨学习

----------------------Talk is cheap, show me the code-----------------------

到了这里,关于Spring高手之路11——BeanDefinition解密:构建和管理Spring Beans的基石的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Spring高手之路-SpringBean的生命周期

    目录 SpringBean的生命周期 整体介绍 详细介绍 1.实例化Bean 2.设置属性值 3.检查Aware 4.调用BeanPostProcessor的前置处理方法 5.调用InitializingBean的afterPropertiesSet方法 6.调用自定义init-method方法 7.调用BeanPostProcessor的后置处理方法 8.注册Destruction回调 9.Bean准备就绪 10.调用DisposableBean的d

    2024年02月03日
    浏览(37)
  • Spring高手之路-Spring在业务中常见的使用方式

    目录 通过IOC实现策略模式 通过AOP实现拦截增强 1.参数检验 2.缓存逻辑 3.日志记录 通过Event异步解耦 通过Spring管理事务 1.声明式事务 2.编程式事务 3.需要注意的问题 不能在事务中处理分布式缓存 不能在事务中执行 RPC 操作 不过度使用声明式事务 很多时候,我们需要对不同的

    2024年01月19日
    浏览(44)
  • Spring高手之路9——掌握Spring条件装配的秘密武器

      在 Spring 框架中,条件装配( Conditional Configuration )是一个非常重要的特性,它允许开发者根据满足的条件,动态地进行 Bean 的注册或是创建。这样就可以根据不同的环境或配置,创建不同的 Bean 实例,这一特性对于创建可配置和模块化的应用是非常有用的。 Spring 提供了一

    2024年02月16日
    浏览(44)
  • Spring高手之路10——解锁Spring组件扫描的新视角

      首先,我们将探讨一些 Spring 框架中 IOC ( Inversion of Control )的高级特性,特别是组件扫描的相关知识。组件扫描是 Spring 框架中一个重要的特性,它可以自动检测并实例化带有特定注解(如 @Component , @Service , @Controller 等)的类,并将它们注册为 Spring 上下文中的 bean 。这

    2024年02月16日
    浏览(47)
  • Spring高手之路5——彻底掌握Bean的生命周期

    在 Spring IOC 容器中, Bean 的生命周期大致如下: 实例化:当启动 Spring 应用时, IOC 容器就会为在配置文件中声明的每个 bean 创建一个实例。 属性赋值:实例化后, Spring 就通过反射机制给 Bean 的属性赋值。 调用初始化方法:如果 Bean 配置了初始化方法, Spring 就会调用它。

    2024年02月09日
    浏览(38)
  • Spring高手之路-@Autowired和@Resource注解异同点

    目录 概述 相同点 1.都可以实现依赖注入 2.都可以用于注入任意类型的Bean 3.都支持通过名称、类型匹配进行注入 不同点 1.来源不同。 2.包含的属性不同 3.匹配方式(装配顺序)不同。 4.支持的注入对象类型不同 5.应用地方不同 @Autowired 和 @Resource 是在 Java 开发中用于实现依赖

    2024年02月03日
    浏览(45)
  • Spring高手之路3——揭秘Spring依赖注入和SpEL表达式

    本篇会给大家举出各种 Spring 属性依赖注入的例子,方便大家理解。 我们在前面的文章中已经使用过 XML 进行 setter 方法的属性注入了,下面让我们再来回顾一下: 我们在前面的文章中也学习过如何在 bean 创建时通过编程方式设置属性: 使用XML进行setter方法注入 首先,我们需

    2024年02月08日
    浏览(40)
  • Spring高手之路8——Spring Bean模块装配的艺术:@Import详解

      在 Spring 中,手动装配通常是指通过 XML 配置文件明确指定 Bean 及其依赖,或者在代码中直接使用 new 创建对象并设定依赖关系。   然而,随着 Spring 2.0 引入注解,以及 Spring 3.0 全面支持注解驱动开发,这个过程变得更加自动化。例如,通过使用 @Component + @Compo

    2024年02月13日
    浏览(33)
  • Spring高手之路13——BeanFactoryPostProcessor与BeanDefinitionRegistryPostProcessor解析

       BeanFactoryPostProcessor 位于 org.springframework.beans.factory.config 包中。它与 BeanPostProcessor 有相似的核心逻辑,但它们之间的主要区别在于它们所操作的对象。 BeanFactoryPostProcessor 的主要目的是对 Bean 的配置元数据进行操作,这意味着它可以影响 Bean 的初始配置数据。   在 Sp

    2024年02月11日
    浏览(35)
  • Spring高手之路15——掌握Spring事件监听器的内部逻辑与实现

    在阅读本文之前需要你已经对事件监听器有了简单的了解,或去阅读前面的文章《 Spring高手之路7——事件机制与监听器的全面探索 》   在 Spring 中, ApplicationContext 可以形成一个层次结构,通常由主容器和多个子容器组成。一个常见的疑问是:当一个事件在其中一个容器

    2024年02月06日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包