基于spring 3.1java
@Enable...系列能够实现按需加载整个模块,从而达到简化配置的目的。咱们以@EnableCaching
为例子spring
@Target({ElementType.TYPE}) @Retention(RetentionPolicy.RUNTIME) @Documented @Import({CachingConfigurationSelector.class}) public @interface EnableCaching { boolean proxyTargetClass() default false; AdviceMode mode() default AdviceMode.PROXY; int order() default 2147483647; }
因此魔法就在 @Import这里,@Import能够导入Configuration class, ImportSelector,ImportBeanDefinationRegister的实现类,至少申明一个@Bean方法的类,并将它们注册为bean。code
在上一篇中<context:component-scan/>
会将须要spring 注册的bean定义为BeanDefination。而后交由不一样的bean. parser.component
spring3. 以后由ConfigurationClassPostProcessor
来处理@Configuration @Bean and @Component. 其中 ConfigurationClassParser.processConfigurationClass(ConfigurationClass)
处理了@Import 相关注解xml
// 加载注解对应的处理器 <context:annotation-config/> <context:component-scan base-package="com.xxx"/>
这两种方式能够作更多的自定义操做。get
因此在spring framework时代,@Component ,@Configuration 须要被装载时,应用须要借助@Import 或者@ComponentScan 的能力, 也是咱们一般须要经过@ComponentScan 扫描对应默认的包路径。it
这样存在的问题:io
因此催生出了spring boot的自动装配。class