spring mvc流程, bean实例化方式,生命周期,作用域

参阅

1、spring框架

spring 核心框架体系结构(jar 包依赖)
SpringMVC系列源码解析 ----棒棒

2、spring bean作用域,实例化,注入,生命周期

关于Spring IOC (DI-依赖注入)你需要知道的一切 ---全面

Spring学习(十五)Spring Bean 的5种作用域介绍

singleton、prototype、request、session、global session

Spring学习(十四)Spring Bean 的3种实例化方法介绍

Spring Bean 生命周期
Spring Bean的生命周期(非常详细)

1. 实例化Bean
对于BeanFactory容器,当客户向容器请求一个尚未初始化的bean时,或初始化bean的时候需要注入另一个尚未初始化的依赖时,容器就会调用createBean进行实例化。
对于ApplicationContext容器,当容器启动结束后,便实例化所有的bean。
容器通过获取BeanDefinition对象中的信息进行实例化。并且这一步仅仅是简单的实例化,并未进行依赖注入。
实例化对象被包装在BeanWrapper对象中,BeanWrapper提供了设置对象属性的接口,从而避免了使用反射机制设置属性。

2. 设置对象属性(依赖注入)
实例化后的对象被封装在BeanWrapper对象中,并且此时对象仍然是一个原生的状态,并没有进行依赖注入。
紧接着,Spring根据BeanDefinition中的信息进行依赖注入。 并且通过BeanWrapper提供的设置属性的接口完成依赖注入。

3. 注入Aware接口
紧接着,Spring会检测该对象是否实现了xxxAware接口,并将相关的xxxAware实例注入给bean。

4. BeanPostProcessor
当经过上述几个步骤后,bean对象已经被正确构造,但如果你想要对象被使用前再进行一些自定义的处理,就可以通过BeanPostProcessor接口实现。 该接口提供了两个函数:

  • postProcessBeforeInitialzation( Object bean, String beanName )
    当前正在初始化的bean对象会被传递进来,我们就可以对这个bean作任何处理。 这个函数会先于InitialzationBean执行,因此称为前置处理。 所有Aware接口的注入就是在这一步完成的。
  • postProcessAfterInitialzation( Object bean, String beanName )
    当前正在初始化的bean对象会被传递进来,我们就可以对这个bean作任何处理。 这个函数会在InitialzationBean完成后执行,因此称为后置处理。

5. InitializingBean与init-method
当BeanPostProcessor的前置处理完成后就会进入本阶段。
InitializingBean接口只有一个函数:

  • afterPropertiesSet()

这一阶段也可以在bean正式构造完成前增加我们自定义的逻辑,但它与前置处理不同,由于该函数并不会把当前bean对象传进来,因此在这一步没办法处理对象本身,只能增加一些额外的逻辑。 若要使用它,我们需要让bean实现该接口,并把要增加的逻辑写在该函数中。然后Spring会在前置处理完成后检测当前bean是否实现了该接口,并执行afterPropertiesSet函数。
当然,Spring为了降低对客户代码的侵入性,给bean的配置提供了init-method属性,该属性指定了在这一阶段需要执行的函数名。Spring便会在初始化阶段执行我们设置的函数。init-method本质上仍然使用了InitializingBean接口。

6. DisposableBean和destroy-method
和init-method一样,通过给destroy-method指定函数,就可以在bean销毁前执行指定的逻辑。

spring中bean配置和bean注入 ---棒棒哒

  • bean配置有三种方法:
  • 1、基于xml配置Bean
  • 2、使用注解定义Bean
  • 3、基于java类提供Bean定义信息
  • bean注入四种方式:
  • 1、属性注入 (set注入)
  • 2、构造函数注入
  • 3、工厂方式注入:
    静态工厂:factory-method
    实例工厂:factory-bean
  • 4、注解注入
  • spring循环依赖:
    Spring 中如何控制2个bean中的初始化顺序?
    Spring循环依赖的解决方案
    Spring循环依赖正确性及Bean注入的顺序关系详解

三级缓存
第一级缓存singletonObjects里面放置的是实例化好的单例对象。
第二级earlySingletonObjects里面存放的是提前曝光的单例对象(没有完全装配好)。
第三级singletonFactories里面存放的是要被实例化的对象的对象工厂

3、spring 流程,IOC,AOP

SpringMVC执行流程及工作原理
Spring AOP实现原理
Java Proxy和CGLIB动态代理原理 --很详细
JDK和CGLIB生成动态代理类的区别

jdk动态代理:此时代理对象和目标对象实现了相同的接口,目标对象作为代理对象的一个属性
cglib动态代理:主要是对指定的类生成一个子类,覆盖其中的所有方法,所以该类或方法不能声明称final的。

  • Spring AOP代理对象的生成

Spring提供了两种方式来生成代理对象: JdkProxy和Cglib,具体使用哪种方式生成由AopProxyFactory根据AdvisedSupport对象的配置来决定。默认的策略是如果目标类是接口,则使用JDK动态代理技术,否则使用Cglib来生成代理。


Spring 容器启动完成后,执行初始化加载工作

AOP/Spring AOP/Filter/拦截器 释义

SpringMVC 启动流程及相关源码分析

  • 初始化执行顺序
    @PostConstruct > init-method > InitializingBean ( afterPropertiesSet ) > ServletContextAware

Spring bean创建的流程:
getBean()->创建实例->autowired->set属性->afterPropertiesSet

  • DispatchServlet类和ContextLoaderListener类的关系图:

  • ContextLoaderListener 配置在 web.xml 中, 在容器启动时初始化.

  • DispatcherServlet 配置在 web.xml 中, 在第一次访问时初始化.

  • bean与spring容器的关系

  • springMVC执行流程

你可能感兴趣的:(spring mvc流程, bean实例化方式,生命周期,作用域)