spring的后置处理器有很多,其中有一个后置处理器可以在bean初始化中对其进行一定的影响。我们下面来看看
接上文的Teacher类
@Component
@Scope("singleton")//加与不加,spring默认是注册单例bean
public class Teacher{
public Teacher(){
System.out.println("Construct");
}
@PostConstruct//使用该注解实现执行初始化方法
public void init(){
System.out.println("init");
}
}
@Scope("singleton")小知识:面试官通常会问到在spring框架里面面向接口编程的环境中,有没有使用过单例,说实话很多人都不知道,就我面过的3年及以下没一个人知道,我们通常@Service和@Controller注解修饰的一个对象,这个对象就是一个单例的bean,那么我们使用@Autowired 和@Resource注解注入的bean就是单例的,这是一个非常简单的问题,可惜你们都不知道。
自定义实现类
@Component
public class TestBeanPostProcessor implements BeanPostProcessor, PriorityOrdered {
@Override
public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
if(beanName.equals("teacher")){
System.out.println("BeforeInitialization10");
}
return bean;
}
@Override
public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
if(beanName.equals("teacher")){
System.out.println("AfterInitialization10");
}
return bean;
}
@Override
public int getOrder() {
return 10;
}
}
说明:主接口BeanPostProcessor,而PriorityOrdered接口顾名思义就是注册列表中用来排序的主角
BeanPostProcessor重写了两个bean初始化之前后之后的操作,最后将这个Bean返回即可,当然我们可以返回代理对象
这个类我们也交给了spring 管理,当然根据上面的文章也可以用自定义注解的方式来灵活开启
下篇介绍上问提到的@Configuration这个注解