【Spring IOC容器】底层原理



一、IOC概念和原理

概念

在这里插入图片描述
(1)控制反转,把对象创建和对象之间的调用过程,交给 Spring 进行管理
(2)使用 IOC 目的:为了耦合度降低
(3)做入门案例就是 IOC 实现


原理

  • xml 解析
  • 工厂模式
  • 反射

举个例子,假设我们有两个类,各自含有方法,其中UserService类要去调用UserDao类的方法:
在这里插入图片描述

  • 使用原始的方式,直接在UserService类中new出UserDao类的对象,通过对象引用去调用方法。但是这种方式的耦合度太高了,也就是说对于这两个类之间的依赖太高,牵一发而动全身~
    在这里插入图片描述

  • 还有一种思想是工厂模式,通过创建一个对象工厂,来实现(如上图所示)。但是,这种模式同时也还具有耦合度的问题。

  • 为了降低耦合度带来的问题,我们就使用到了IOC容器,在利用工厂模式的基础之上,又添加了xml解析反射(通过得到类的字节码文件来操作类中所有内容)。
    在这里插入图片描述

  • 1.通过配置文件,配置需要创建的对象

  • 2.创建工厂类,创建方法

    • 2.1 通过xml解析获取对象的class属性
    • 2.2 通过Class.forName()反射创建对象
    • 2.3 将对象返回出去

优点:当类改变的时候,只需要修改xml文件就可以,进一步降低了耦合度!

返回顶部


二、IOC(接口)

IOC主要接口

IOC 思想基于 IOC 容器完成,IOC 容器底层就是对象工厂.

Spring 提供 IOC 容器实现两种方式:(两个接口)

  • BeanFactory:IOC 容器基本实现,是 Spring 内部的使用接口,不提供开发人员进行使用

    • 加载配置文件时候不会创建对象,在获取对象(使用)才去创建对象
  • ApplicationContext:BeanFactory 接口的子接口,提供更多更强大的功能,一般由开发人员进行使用

    • 加载配置文件时候就会把在配置文件对象进行创建

以上两者的作用是都可以去解析xml文件创建对象,可以互换;区别就是创建对象的时期。
在这里插入图片描述

一般来说,整个项目的运行会配有tomcat服务器。所以为了节约资源,在启动服务器的同时,就让类去进行加载,同时创建对象,而不是等到用的时候才去创建,那样既耗时又耗资源,所以一般采用ApplicationContext接口来实现。

返回顶部


ApplicationContext接口主要实现类

在这里插入图片描述

  • ClassPathXmlApplicationContext 从类路径下的一个或多个xml配置文件中加载上下文定义,适用于xml配置的方式

在这里插入图片描述

  • FileSystemXmlApplicationContext 从文件系统下的一个或多个xml配置文件中加载上下文定义,也就是说系统盘符中加载xml配置文件。
    在这里插入图片描述

返回顶部


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

骑着蜗牛ひ追导弹'

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值