第一篇:Spring IOC 学习一
第三篇:Spring IOC 学习三 之ApplicationContext容器面纱
上篇就讲到 loadBeanDefinitions()方法了,该方法是一个抽象方法具体实现是在子类AbstractXmlApplicationContext 整个方法具体实现入截图:
每段代码上都有解释,就不一一写在下面了。
可以看到最后一行代码又是loadBeanDefinitions()这次传的参数确实 XmlBeanDefinitionReader实例具体操作我们看一下。
首先获取Resource结构是否为空,如果不为空则执行如下接口
上面loadBeanDefinitions(resoruce)方法在接口BeanDefinitionReader中,具体实现却又三个如下:
因为我用的是ClassPathXmlApplicationContext 所以我们就选择XmlBeanDefinitionReader进入,重载的时候讲resource进行了重编码
上面代码中我们就能看到,
1、先是加载当前加载过的资源。
2、如果已经存在了当前资源就抛出异常
3、然后将resource转成inputStream,再转成inputSource
4、核心方法就是 从对应的xml中加载beanDefinition 。doLoadBeanDefinitions(inputSource, encodedResource.getResource());
这里重要2行代码,
一是将资源转成document结构,
二是从给定的doc结构中注册bean definitions 代码如下:
1、通过反射方式完成BeanDefinitionDocumentReader的实例 代码如下:
2、从给定的DOM文档中读取bean定义,并在给定的读取器上下文中将它们注册到注册表中
第一步:获取用于解析XML bean定义的有状态委托类实例
第二步:判断是否Spring bean结构,如果是的判断是否有profile 属性,则直接return(因为spr12458不能使用profile .of(…),因为XML config不支持profile表达式)
第三步:解析xml文件内容
详细结构:
整个资源文件的解析委托链有以下四个主要类:
ClassPathXmlApplicationContext,作为最外围的组件,发起解析的请求
XmlBeanDefinitionReader,将配置文件路径封装为Resource,读取出w3c定义的Document对象,然后委托给
DefaultBeanDefinitionDocumentReader,接着上面的委托开始做实际的解析工作,因为需要非常详细的解析每一个bean,所以它又会继续委托给
BeanDefinitionParserDelegate,最终解析类。进入该类就会发现很多xml种的属性名称
部分截图:
OK ,容器对XML的解析基本就结束了。