上篇文章介绍了BeanFactoryPostProcessor接口,在bean创建对象之前,如何执行的:
BeanFactoryPostProcessor--- Spring源码从入门到精通(二十七)
这篇文章主要介绍他的子接口:
beanDefinitionRegisterPostProcessor:所有bean的定义信息将要被加载,在bean创建对象之前调用。
和上篇文章的BeanFactoryPostProcessor不同,上篇文章是:所有bean的定义信息已经加载进入beanFactory里,在bean创建对象之前调用。
其实从源码中我们也可以看到,beanDefinitionRegisterPostProcessor是extends BeanFactoryPostProcessor,所以定义类实现他的方法,重写子类的方法在重写父类的方法之前调用。
所以在beanFactoryPostProcessor之前调用,调用完之后,bean的定义信息在被加载进入beanFactory里。
并且以后beanFactory创建的对象,都是根据beanDefinitionRegister定义的信息创建的,用当前接口也能手动注册一个bean进入容器 。
/**
* @author keying
*/
@Component
public class MyBeanDefinitionRegisterPostProcessor implements BeanDefinitionRegistryPostProcessor {
/**
* beanFactory里的bean创建,就是按照BeanDefinitionRegistry定义的bean信息创建的
* @param registry
* @throws BeansException
*/
public void postProcessBeanDefinitionRegistry(BeanDefinitionRegistry registry) throws BeansException {
int count = registry.getBeanDefinitionCount();
System.out.println("当前beanDefinitionRegistry几个 bean:" + count);
String beanName = "registerBean";
//下面两个方法效果都是一样的:注册一个bean
//RootBeanDefinition rootBeanDefinition = new RootBeanDefinition(Dog.class);
AbstractBeanDefinition rootBeanDefinition = BeanDefinitionBuilder.rootBeanDefinition(Dog.class).getBeanDefinition();
registry.registerBeanDefinition(beanName, rootBeanDefinition);
}
public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
int count = beanFactory.getBeanDefinitionCount();
System.out.println("beanDefinitionRegistry当前beanFactory几个 bean:" + count);
}
}
junitTest和上篇文章一样不变,为了方便理解再贴一次:
@Test
public void test() {
AnnotationConfigApplicationContext applicationContext = new AnnotationConfigApplicationContext(ExtConfig.class);
applicationContext.close();
}
从控制台打印可以看到,自己注册的bean对象成功注入容器,并且beanDefinitionRegistryPostProcessor的方法是在beanFactoryPostProcessor方法之前执行的:
从打断点可以看到
A、按类型,从beanFactory中获取到BeanDefinitionRegisterPostProcessor组件。依次循环触发postProcessorBeanDefinitionResgistry。B、按类型再从bean工厂按类型获取BeanProcessorBeanFactory。依次循环触发postPorcessorBeanFactory方法。