【修真院JAVA小课堂】IOC实现

大家好,我是我是深圳分院第十期java学员,一枚正直纯洁善良的Java程序员。今天给大家分享一下,修真院官网java任务一,Spring IOC 实现。

   1.背景介绍

程序的性质:

内聚:每个模块尽可能独立完成自己的功能,不依赖于模块外部的代码。

耦合:模块与模块之间接口的复杂程度,模块之间联系越复杂耦合度越高,牵一发而动全身。

目的:使得模块的“可重用性”、“移植性”大大增强

通常程序结构中各模块的内聚程度越高,模块间的耦合程度就越低

如何减少耦合度?

    2.知识剖析

第一个重要概念:Ioc—Inversion of Control,即“控制反转”,是一种设计思想

●谁控制谁,控制什么?

谁控制谁?当然是IoC 容器控制了对象;

控制什么?

那就是主要控制了外部资源获取(不只是对象包括比如文件等)

第二个重要概念: DI(Dependency Injection,依赖注入)

?哪来的

一个对象的创建往往会涉及到其他对象的创建,比如一个对象A的成员变量持有着另一个对象B的引用,这就是依赖

通过将依赖关系写入配置文件,然后在创建有依赖关系的对象时,由IOC容器注入依赖的对象

    3DI实现方式

DI实现方式大概有四种:主要应用只有两种,所以就只举两个

1,setter方法

2,构造器方法

   4.编码实战

   5.扩展思考

1.创建Ioc配置文件的抽象资源,这个抽象资源包含了BeanDefinition的定义信息

2.创建一个BeanFactory,这里使用了DefaultListableBeanFactory

3.创建一个载入BeanDefinition的读取器,这里使用XmlBeanDefinitionReader来载入XML文件形式的BeanDefinition

4.然后将上面定位好的Resource,通过一个回调配置给BeanFactory

5.从定位好的资源位置读入配置信息,具体的解析过程由XmlBeanDefinitionReader完成

6.完成整个载入和注册Bean定义之后,需要的Ioc容器就初步建立起来了

BeanDefinition

例如类名、scope、属性、构造函数参数列表、依赖的bean、是否是单例类、是否是懒加载等,

  其实就是将Bean的定义信息存储到这个BeanDefinition相应的属性中,后面对Bean的操作就直接对BeanDefinition进行

DefaultListableBeanFactory

spring Ioc容器的实现,从根源上是beanfactory,

  但真正可以作为一个可以独立使用的ioc容器还是DefaultListableBeanFactory

DefaultListableBeanFactory其实要实现的功能就是以list集合的方式操作bean,为什么要拆成这么多的类和接口呢。这里面可能基于几点考虑。

1 功能的不同维度,分不同的接口,方便以后的维护和其他人的阅读。如:AutowireCapableBeanFactory、ListableBeanFactory、HierarchicalBeanFactory等

2 不同接口的实现,分布在不同的之类里,方便以后不同接口多种实现的扩展

3 从整个类图的分布,可以看出spring在这块是面向接口编程,后面类的实现,他们认为只是接口功能实现的一种,随时可以拓展成多种实现

XmlBeanDefinitionReader

XmlBeanDefinitionReader并不是xml配置的真正解析者,它只是相当于一个指挥官。当它收到一条需要加载BeanDefinition对象的任务后,它只会协调手下去完成相应的工作

  5.编码实战(注解法)

@Required 注释应用于 bean 属性的 setter 方法,它表明受影响的 bean 属性在配置时必须放在 XML 配置文件中

setter方法上使用@Autowired注释来摆脱XML配置文件中的元素。

当Spring发现使用setter方法的@Autowired注释时,它会尝试在方法上执行autowire="byType"的自动连接。

   6.参考文献

百度,博客

   7.更多讨论

今天的分享就到这里啦,欢迎大家提问和探讨!

提问二:Xml ref与value区别?

ref全名是reference.一般赋值或者加载配置文件的的时候使用value,引用或者注入的时候使用ref

提问二:构造注入的时候可以使用name吗?

可以的,我们查看constructor-arg源码时是可以看到有name的,所以可以调用。

提问三:IOC具体为什么提出的?

因为需要实现低耦合,所以提出了这个IOC可以解决多成员之间进行同个项目的分工

猜你喜欢

转载自blog.csdn.net/as4566/article/details/80292987