自动装配的核心精髓到底是什么
在 link-flow 中,通过 @AutoConfigureBefore 注解来实现让自己定义的配置先于原有的配置进行加载,如下:
@AutoConfigureBefore(LoadBalancerClientConfiguration.class)
public class WorkLoadBalancerClientConfiguration {
//省略
}
这样可以让 WorkLoadBalancerClientConfiguration 先于 LoadBalancerClientConfiguration 进行加载
关于 @AutoConfigureBefore 的介绍,可以跳转到 技术精华讲解-@AutoConfigureBefore的作用 的章节
而本章节将详细讲解 @AutoConfigureBefore 和自动装配的关系
案例1
@Configuration
public class SchoolConfig {
@ConditionalOnBean(Student.class)
@Bean
public School school(){
System.out.println("school对象加载创建");
return new School();
}
}
@Configuration
public class StudentConfig {
@Bean
public Student student(){
System.out.println("student对象加载创建");
return new Student();
}
}
结果
student对象加载创建
发现只有student对象加载了,但school的加载条件是说当student对象存在时,school对象也会加载,现在并没有,那可能是普通配置类的问题,那就把它变成自动装配试试
案例2
public class SchoolConfig {
@ConditionalOnBean(Student.class)
@Bean
public School school(){
System.out.println("school对象加载创建");
return new School();
}
}
public class StudentConfig {
@Bean
public Student student(){
System.out.println("student对象加载创建");
return new Student();
}
}
自动装配文件
com.example.config.SchoolConfig
com.example.config.StudentConfig
结果
student对象加载创建
发现还是只有student对象加载了,school对象还是没加载,这要怎么处理呢?
beanDefinition
要先知道一个概念,Spring在创建对象时,不是直接就把对象创建出来,而是先获取创建对象的元信息(类名、构造方法、属性值等)包装成 BeanDefinition 结构,再放入一个 beanDefinition 类型的Map结构中,等把所有对象元信息都放入此map后,接着再遍历这个map,把真正的对象创建出来。