对IOC的理解

容器概念、控制反转、依赖注入

ioc容器:实际上就是个map(key,value),里面存的是各种对象(在xml里配置的bean节点、@repository、@service、@controller、@component),在项目启动的时候会读取配置文件里面的bean节点,根据全限定类名使用反射创建对象放到map里,扫描到打上上述注解的类还是通过反射创建对象放到map中。
这个时候map里面就有各种对象,接下来我们在代码中需要用到里面的对象时,再通过DI注入(autowired、resource等注解,xml里bean节点内的ref属性,项目启动时会读取xml节点ref属性根据id注入,也会扫描这些注解,根据类型或者id注入;id就是对象名)。

控制反转:没有引入IOC容器之前,对象A依赖于对象B,那么对象A在初始化或者运行到某一点的时候,对象A自己必须主动去创建对象B或者使用已经创建的对象B,无论是创建还是使用对象B,控制权都在对象A手上。
引入IOC容器之后,对象A与对象B之间失去了直接联系,当对象A运行到需要对象B的时候,IOC容器会主动创建一个对象B注入到对象A需要的地方。

  1. 通过前后对比,可以看出:对象A获得依赖对象B的过程,由主动行为变成了被动行为,控制权颠倒过来了,这个就是“控制反转”这个名称的由来。
  2. 全部对象的控制权全部给“第三方”IOC容器,所以IOC容器变成整个系统的关键核心,它起到了一种类似于“粘合剂”的作用,把系统中的所有对象粘合在一起发挥作用,如果没有这个“粘合剂”,对象与对象之间会彼此失去联系,这就把IOC容器比喻成“粘合剂”的由来。
  3. 依赖注入:是实现IOC的方法,就是由IOC容器在运行期间,动态的将某种依赖关系注入到对象之中。“获得依赖对象的过程被反转了”,控制被反转之后,获得依赖对象的过程由自身管理变成了由IOC容器主动注入。

实现一个IOC容器
步骤:
1.在配置文件中配置包扫描路径
2.递归包扫描,获取.class文件
3.反射、确定需要交给IOC管理的类
4.对需要注入的类进行依赖注入

注意:

  • 配置文件中指定需要扫描的包路径
  • 定义一些注解,分别表示访问控制层、业务服务层、数据持久层、依赖注入注解、获取配置文件注解
  • 从配置文件中获取需要扫描的包路径,获取到当前路径下的文件信息和文件夹信息,我们将当前路径下所有以.class结尾的文件添加到一个Set集合中进行存储
  • 遍历这个set集合,获取在类上有指定注解的类,并将其交给IOC容器,定义一个安全的Map用来存储这些对象
  • 遍历这个IOC容器,获取每一个类的实例,判断里面是有有依赖其他的类的实例,然后及逆行递归注入
上一篇:Spring IOC_容器设计原理


下一篇:2021年一起努力应对互联网寒冬吧,字节跳动Java高级工程师