一.@ConditionalOnMissingBean:
先看下官方解释
从上图主要可以得到如下信息:
- 仅当BeanFactory中已没有满足指定要求的Bean时才匹配
- 当放置在@Bean方法上时,Bean类默认为工厂方法的返回类型:
- 该条件只能匹配到目前为止已由应用程序上下文处理的Bean定义,因此,强烈建议仅在自动配置类上使用该条件。如果候选Bean可能是由另一个自动配置创建的,请确保使用此条件的Bean在之后运行。
简单的说其实就是只有当BeanFactory中没有指定的bean的时候才能匹配,主要是用来做自动配置的,当程序没有配置指定的类的时候,就会使用默认配置
用下面简单的例子说下
@Service
public class UserService implements InitializingBean {
@Override
public void afterPropertiesSet() throws Exception {
System.out.println("1111111111111111");
}
}
@Service
//当Bean工厂没有UserService的bean的话才创建UserService2的Bean
@ConditionalOnMissingBean(UserService.class)
public class UserService2 implements InitializingBean {
@Override
public void afterPropertiesSet() throws Exception {
System.out.println("222222222");
}
}
运行效果
只有11111111 ,UserService2 无法创建bean因为在创建UserService2 时 UserService已经创建了。
因此在使用@ConditionalOnMissingBean一定要确保使用此条件的Bean在之后运行。不然会失效请看以下情况
@Configuration
public class TestConfig {
@Bean
@ConditionalOnMissingBean(UserService.class)
public UserService2 userService2() {
return new UserService2();
}
@Bean
@DependsOn("userService2")
public UserService userService() {
return new UserService();
}
}
运行效果两个bean都被创建了
这里是因为 @DependsOn(“userService2”) 在加载UserService 必须先加载UserService2这样就导致 @ConditionalOnMissingBean(UserService.class)失效。
其它注释及总结:
- @ConditionalOnBean // 当给定的在bean存在时,则实例化当前Bean
- @ConditionalOnMissingBean // 当给定的在bean不存在时,则实例化当前Bean
- @ConditionalOnClass // 当给定的类名在类路径上存在,则实例化当前Bean
- @ConditionalOnMissingClass // 当给定的类名在类路径上不存在,则实例化当前Bean