首先我们初始化一个最简单的容器,用这个容器研究初始化的流程。
下面就是一个再简单不过的IoC容器了,该容器包含了一个名为beanA的bean,我们初始化容器后,取出该Bean,并调用方法。
public class BeanA { private String testStr = "Test"; public BeanA(){ System.out.println("Running A"); } public void sayHello(){ System.out.println("I'm beanA."); } }
<&#63;xml version="1.0" encoding="UTF-8"&#63;>
@Test void testHello(){ Resource springResource=new ClassPathResource("spring-beans.xml"); BeanFactory beanFactory=new XmlBeanFactory(springResource); BeanA beanA= (BeanA) beanFactory.getBean("beanA"); beanA.sayHello(); }
虽然XmlBeanFactory已经被Spring标记为过时,但是为了达到我们从一个xml定义的bean信息构造一个BeanFactory的目的,勉为其难,还是先用一下233。
这段代码很简单,但是反映了我们使用IoC的一个基础流程:
我们就先从这几点一点点讲
在开始之前,需要意识到的是:Spring作为一款优秀的面向对象的框架设计,Spring中采用了大量的设计模式并按照面向对象的逻辑对各个类进行设计,做到了各个类功能单一。
这意味着,Spring的代码会有一种剥洋葱的感觉,子类对双亲扩展,调用默认实现。
构建数据源的部分难度不大,会稍微简单点讲
这里推荐一本书:《Spring源码深度解析(第2版)》
看了Spring的设计,这是真的面向对象。
Spring一开始是使用大量的xml文件配置了容器。从面向对象的角度思考,为了方便使用,需要将各种资源都被抽象出来,先看一下他的资源类结构体系。该部分是系统最底层,在core包中
InputStreamSource封装能返回InputStream的类,可以返回这个流。
日常开发用Spring的体系也会很便捷。
Resource体系达到了这样的目的:对于不同的文件来源都有一种实现来读取该文件,同时,拥有一个规范的接口。
现在我们有了Resource的设计,为了读取对象,Spring提供了BeanDefinitionReader、ResourceLoader来从资源中提取出我们需要的资源内容。这些类的关系如下:
这就是大致的一个逻辑,把握住这个大致的逻辑看源码,体验要上升不少
下面是最上方的例子启动的大致的流程,大量的代码在处理读取资源的逻辑
这里就是初始化的结果了
到此这篇关于一个简单的Spring容器初始化流程的文章就介绍到这了,更多相关Spring容器初始化流程内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!