Spring源码分析(一)-导读

本系列博文全部分析基于Spring4.0.0.RELEASE版本

先看一个Spring的最基本使用

LoginService.java

public class LoginService {
    public void login() {
        System.out.println("execute LoginService");
    }
}

public class LoginResource {
    private LoginService loginService;
    
    public LoginService getLoginService() {
        return loginService;

    public void setLoginService(LoginService loginService) {
        this.loginService = loginService;
    }
    
    public void login() {
        loginService.login();
    }
}

applicationgContext.xml

<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns="http://www.springframework.org/schema/beans"
       xsi:schemaLocation="http://www.springframework.org/schema/beans        http://www.springframework.org/schema/beans/spring-beans.xsd        ">

    <bean id="loginService" name="loginService" class="spring.LoginService"/>
    
    <bean id="loginResource" name="loginResource" class="spring.LoginResource">
        <property name="loginService" ref="loginService"/>
    </bean>
</beans>

TestClient.java

public class TestClient {
    @Test
    public void test() {
        ApplicationContext applicationContext = new ClassPathXmlApplicationContext("applicationgContext.xml");
        LoginResource loginResource = (LoginResource) applicationContext.getBean("loginResource");
        loginResource.login();
    }
}

概括性描述Spring的操作:

  • 解析applicationgContext.xml,将xml中定义的bean解析成Spring内部的BeanDefinition
  • 以bean name(如loginService,String类型)为key,bean definition objects(也就是上面的BeanDefinition)(如loginService相应的BeanDefinition)为value存储到DefaultListableBeanFactory中的beanDefinitionMap(一个ConcurrentHashMap)
  • 同时将bean name存入beanDefinitionNames(List类型)中,然后遍历beanDefinitionNames中的bean name
  • 进行bean的实例化并填充属性,在实例化的过程中,如果有依赖没有被实例化将先实例化其依赖,然后实例化本身
  • 实例化完成后将实例存入单例bean的缓存中
  • 当调用getBean方法时,到单例bean的缓存中查找,如果找到并经过转换后返回这个实例(如LoginResource的实例),之后就可以直接使用了

以上只是一个简单的描述,具体实现过程还是很复杂的,后续将深入源码分析实现,如有错误之处还请不吝赐教!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏逆向技术

内核开发知识第一讲.内核中的数据类型.重要数据结构.常用内核API函数.

  在内核中.程序的编写不能简单的用基本数据类型了. 因为操作系统不同.很有可能造成数据类型的长度不一.而产生重大问题.所以在内核中.

1732
来自专栏郭霖

Android图片加载框架最全解析(四),玩转Glide的回调与监听

大家好,今天我们继续学习Glide。 在上一篇文章当中,我带着大家一起深入探究了Glide的缓存机制,我们不光掌握了Glide缓存的使用方法,还通过源码分析对缓...

6136
来自专栏博岩Java大讲堂

Java日志体系(slf4j)

9996
来自专栏java工会

Java RMI之HelloWorld,你不可不知的RPC协议

1646
来自专栏Java呓语

DataBinding·常用注解说明

Observable接口提供给开发者添加/移除监听者的机制。为了使开发更便捷,我们创建了BaseObservable类,它已经实现了Observable接口中的...

1414
来自专栏求索之路

Android源码设计模式解析与实战笔记

1.单一职责原则:比如说一个ImageLoader,需要加载图片的缓存图片,此时如果将这两个功能都放在一个类中,就违反了这个原则, 我们需要将不同的功能用类精...

4645
来自专栏Java编程技术

Velocity引擎原理探究

常见的Java模板引擎有JSP、Freemark,Velocity。在MVC三层框架中,模板引擎属于view层,实质是把model层内容展现到前台页面的一个引擎...

1662
来自专栏个人分享

Netty的TCP粘包/拆包(源码二)

假设客户端分别发送了两个数据包D1和D2给服务器,由于服务器端一次读取到的字节数是不确定的,所以可能发生四种情况:

2274
来自专栏大闲人柴毛毛

深入剖析Spring(二)——IoC容器的实现

Spring的两种IoC容器 BeanFactory 基础类型的IoC容器; 采用延迟初始化策略(容器初始化完成后并不会创建bean的对象,只有当收到初...

3554
来自专栏java学习

Spring学习笔记3_Bean 获取与实例化

本章目录 Spring学习笔记3_Bean 获取与实例化 1.ApplicationContext与BeanFactory关系 2.Bean的实例化方式 ...

3158

扫码关注云+社区

领取腾讯云代金券