一
简要说明Spring什么时候实例化bean,首先要分2种情况
第一:如果你使用BeanFactory作为Spring Bean的工厂类,则所有的bean都是在第一次使用该Bean的时候实例化
第二:如果你使用ApplicationContext作为Spring Bean的工厂类,则又分为以下几种情况:
(1):如果bean的scope是singleton的,并且lazy-init为false(默认是false,所以可以不用设置),则 ApplicationContext启动的时候就实例化该Bean,并且将实例化的Bean放在一个map结构的缓存中,下次再使用该Bean的时候,
直接从这个缓存中取
(2):如果bean的scope是singleton的,并且lazy-init为true,则该Bean的实例化是在第一次使用该Bean的时候进行实例化
(3):如果bean的scope是prototype的,则该Bean的实例化是在第一次使用该Bean的时候进行实例化
二
Spring中Bean的实例化过程

打印Spring初始化bean的时间
-
@Service
-
publicclassBeanPostProcessorImplimplementsBeanPostProcessor{
-
privatestaticfinalThreadLocal<Long> threadLocal =newThreadLocal<Long>();
-
@Override
-
publicObject postProcessBeforeInitialization(Object o,String s)throwsBeansException{
-
long start =System.currentTimeMillis();
-
threadLocal.set(start);
-
return o;
-
}
-
@Override
-
publicObject postProcessAfterInitialization(Object o,String s)throwsBeansException{
-
System.out.println(o.getClass().getName()+", "+ s+" init time : "+(System.currentTimeMillis()- threadLocal.get()));
-
return o;
-
}
-
} -
三
获取所有bean refresh完事件通知
实现如下接口ApplicationListener<ContextRefreshedEvent>
四
Spring 对同一个文件import多次
-applicationContext.xml(parent)-aContext.xml-bContext.xml(初始化)-cContext.xml(初始化)-bContext.xml(初始化,覆盖原来的bean)-cContext.xml(初始化,覆盖原来的bean)
Spring源码阅读笔记
注册bean的定义代码:
AbstractBeanDefinitionReader.loadBeanDefinitions -->.. --> DefaultListableBeanFactory.registerBeanDefinition
- 如果重复的bean name定义在同一个文件中,那么编译错误
- 如果重复的bean name定义在不同的文件中,类型可以不一样,那么后加载的那个bean会将先加载的bean覆盖掉。(类型不一样时,可能导致其他类的引用出错)——weibo rpc的配置中,如果两个文件引用同一个refer,那么会报错
nested exception is java.lang.IllegalStateException: Duplicate spring bean id。 - 如果多次import同一个文件,那么相当于在不同的文件中定义了相同的bean。
- 如果
allowBeanDefinitionOverriding被设置为false,那么不能有相同名字的bean。 - 使用
BeanPostProcessor打印bean的加载时间,顺序可能跟bean的初始化顺序不一致。
本文探讨了Spring框架中Bean的实例化时机,详细分析了在BeanFactory和ApplicationContext两种场景下,不同scope(singleton, prototype)以及lazy-init属性对Bean实例化的影响。同时,文章还介绍了Spring Bean的实例化过程、如何监听bean初始化时间和注册bean定义的注意事项。"
131682508,8039993,Docker中部署Elasticsearch与Kibana的详细步骤,"['Docker', 'elasticsearch', 'kibana']
423

被折叠的 条评论
为什么被折叠?



