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