zoukankan      html  css  js  c++  java
  • Spring学习

      课余学习一下依赖注入这些东西,觉得有些写的不错,挺有启发意义,但是这个东西是Java上来的,所以就尝试着看了些在Java上的原理解释和应用。

      一、什么是IoC?

      我们先来看一下比较官方的解释。

         IoC,Inversion of Control的缩写,中文名称为控制反转,意思是将对象的控制权转移至第三方,例如IoC容器,即可由IoC容器来管理对象的生命周期、依赖关系等。

      首先我们需要肯定的是IoC并不是特指某种技术,而是指一种思想或者说一种设计模式。因为现在主流语言都是面向对象语言,我们在编程时会创建大量对象,

      

    Object object=new Object();//对象申请
    
    object.setName("XXX");//对象属性初始化赋值

      我们通过语句创建初始化对象,而这些就是所谓的对象的控制权。

    IoC设计模式的目的就是把这些对象的控制权转移至第三方,由第三方来进行和管理类似对象申请、初始化、销毁对象的控制权工作

      对于开发者来说,对象的控制权的转移意味着我们编程将更加简便,不用再去关心如何申请、初始化对象,甚至是管理对象、销毁等复杂的过程,这些都将由第三方完成,只需要告诉第三方我需要怎样的对象使用即可。

       这里还需要解释一个概念,所谓的IoC容器,就是实现了IoC设计模式的框架

    二、依赖注入

       我们可能会遇见这样的情况,Spring IoC容器管理的对象中可能会依赖其他对象,这是很常见的。这就意味着Spring IoC的一个重点是在系统运行中,动态的向某个对象提供它所需要的其他对象。这也是我们接下来要了解的依赖注入

    三、Spring 如何实现IoC?

      Spring IoC实现了IoC设计模式,所以是IoC容器。所以,Spring IoC主要任务就是创建并且管理JavaBean的生命周期,即之前提到的对象的控制权。

    Spring IoC的JavaBean的生命周期

    (1)实例化JavaBean:Spring IoC容器实例化JavaBean
    (2)初始化JavaBean:Spring IoC容器对JavaBean通过注入依赖进行初始化
    (3)使用JavaBean:基于Spring应用对JavaBean实例的使用
    (4)销毁JavaBean:Spring IoC容器销毁JavaBean实例

      Java一个很重要的特性就是支持反射(reflection)机制,它允许程序在运行的时候动态的生成对象、执行对象的方法、改变对象的属性,Spring就是通过反射来实现注入的。

      Spring IoC的实现过程主要分为两部分,即IoC容器初始化、依赖注入。

      

    IoC容器初始化过程主要经过以下几个阶段:  

        1.解析阶段:Spring会解析Bean的XML配置文件,将XML元素进行抽象,抽象成Resource对象。

      2.转换阶段:通过Resource对象将配置文件进行抽象后转换成Spring能够理解的BeanDefinition结构。

      3.注册阶段:Spring IoC容器的实现,从根源上是beanfactory,但真正可以作为一个可以独立使用的ioc容器还是DefaultListableBeanFactory。

      DefaultListableBeanFactory间接实现了BeanFactory接口,是整个bean加载的核心部分,是Spring注册及加载bean的默认实现,我们可以理解为Spring bean工厂的发动机。

       

      1.bean初始化阶段:完成IoC容器初始化后,即上述第一过程后,Spring会加载没有设置lazy-init(延迟加载)属性的bean,进行bean的初始化。

      2.bean实例化阶段:初始化bean,首先需要创建bean实例。

      3.bean属性依赖注入阶段依据BeanDefinition的信息来递归完成依赖注入

    最后对Spring IoC实现做个总结  

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



    作者:Wwwwei
    链接:http://www.jianshu.com/p/dff5484f4c01
    來源:简书
  • 相关阅读:
    Perl的Open函数
    较详细的介绍JNI
    Java多线程单元测试
    sleep函数的简单原理
    Struts与Servlet的冲突
    Ant学习记录
    JDK转码工具
    Throwable
    Entity Framework系列文章导航
    多核时代 .NET Framework 4 中的并行编程1概述
  • 原文地址:https://www.cnblogs.com/sdadx/p/7273777.html
Copyright © 2011-2022 走看看