资源描述:
《2.4 IoC容器的依赖注入(1)》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、2.4 IoC容器的依赖注入假设当前IoC容器已经载入了用户定义的Bean信息,并开始分析依赖注入的原理。首先,注意到依赖注入的过程是用户第一次向IoC容器索要Bean时触发的,当然也有例外,也就是我们可以在BeanDefinition信息中通过控制lazy-init属性来让容器完成对Bean的预实例化。这个预实例化实际上也是一个完成依赖注入的过程,但它在初始化的过程中完成,稍后我们会详细分析这个预实例化的处理。当用户向IoC容器索要Bean时,如果读者还有印象,那么一定还记得在基本的IoC容器接口BeanFacto
2、ry中,有一个getBean的接口定义,这个接口的实现就是触发依赖注入发生的地方。为了进一步了解这个依赖注入过程的实现,我们从DefaultListableBeanFactory的基类AbstractBeanFactory入手去看看getBean的实现,如代码清单2-22所示。代码清单2-22 getBean触发的依赖注入1.//---------------------------------------------------------- 2.---------- 3. // Implementation
3、 of BeanFactory interface. 4. // 这里是对 5.BeanFactory接口的实现,比如getBean接口方法。 6. // 7.这些getBean接口方法最终是通过调用doGetBean来实现的。 8. //-------------------------------------------------- 9.------------------ 10. public Object getBean(String name) throws 11.BeansExc
4、eption { 12. return doGetBean(name, null, null, false); 13. } 14. public T getBean(String name, Class 15.requiredType) throws BeansException { 16. return doGetBean(name, requiredType, null, 17.false); 18. } 19. public Object getBean(S
5、tring name, Object... args) 20.throws BeansException { 21. return doGetBean(name, null, args, false); 22. } 23. public T getBean(String name, Class 24.requiredType, Object[] args) throws 25.BeansException { 1. return doGetBean(name, require
6、dType, args, 2.false); 3. } 4. //这里是实际去取bean的地方,也是触发依赖注入发生的地 5.方。 6. protected T doGetBean( 7. final String name, final Class 8.requiredType, final Object[] args, 9.boolean typeCheckOnly) 10. throws BeansException { 11. fi
7、nal String beanName = 12.transformedBeanName(name); 13. Object bean; 14. // Eagerly check singleton cache for 15.manually registered singletons. 16. 17.//先从缓存中去取,处理已经被创建过的单件模式的bean,对这种bea 18.n的请求不需要重复地创建。 19. Object sharedInstance =
8、 20.getSingleton(beanName); 21. if (sharedInstance != null && args == null) 22.{ 23. if (logger.isDebugEnabled()) { 24. if 25.(isSingletonCu