SpringBeanFactoryポストプロセッサ-BeanFactoryPostProcessor

spring-BeanFactoryPostProcessor有什么功能呢。他能改变bean在实例化之前的一些原注解值,比如单例变原型,手动减轻BeanFactory的工作压力。
原注解是指spring默认为bean装配的注解比如:@Scope,@lazy,@Primary,@DependsOn,@Role,@Description
直接看代码

シングルトンBeanを定義する

@Component
@Scope("singleton")
public class Teacher{


	public Teacher(){
		System.out.println("Construct");
	}

	@PostConstruct
	public void init(){
		System.out.println("init");
	}
}

インターフェースBeanFactoryPostProcessorを実装するプロセッサーをカスタマイズします

@Component
public class TestBeanFactoryPostProcessor implements BeanFactoryPostProcessor {
	@Override
	public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
		BeanDefinition beanDefinition = beanFactory.getBeanDefinition("teacher");
		beanDefinition.setScope("prototype");
		System.out.println("Scope:"+beanDefinition.getScope());
	}
}

これでBeanのスコープ変更は完了ですが、この場所はカスタムTestBeanFactoryPostProcessorをSpring管理に提供するためのものです。

もちろん、@ Importの使用法を理解している人は、カスタムアノテーションを使用してプロセッサの機能を柔軟に有効にするという大胆なアイデアを持っているかもしれません。

まず、クラスがSpring Managementに渡したアノテーション@Componentを削除し、カスタムアノテーションを追加します

@Retention(RetentionPolicy.RUNTIME)
@Documented
@Import(TestBeanFactoryPostProcessor.class)
public @interface TestBeanFactoryPostProcessorAnno {
}

public class TestBeanFactoryPostProcessor implements BeanFactoryPostProcessor {
	@Override
	public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
		BeanDefinition beanDefinition = beanFactory.getBeanDefinition("teacher");
		beanDefinition.setScope("prototype");
		System.out.println("Scope:"+beanDefinition.getScope());
	}
}

 

カスタムアノテーションを構成クラスに追加して、柔軟に開きます

@Configuration
//@Import(TestImportSelector.class)
//@TestImportSelectorAnno
@TestBeanFactoryPostProcessorAnno
@ComponentScan("org.springframework.test.main.*")
public class ScanConfig {
}
@Configuration这个注解加与不加程序一样能完整跑下去,但是加与不加有什么区别呢,我们后期再提。

おすすめ

転載: blog.csdn.net/qq_38108719/article/details/100591053