2.1、IOC的原型
原来的JavaWeb架构:
1.UserDao接口
2.UserDaoImpl实现类
3.UserService业务接口
4.UserServiceImpl业务实现类
在我们之前的业务中, 用户的需求可能会影响我们的原代码、我们需要根据用户的需求去修改源代码! 如果程序代码量十分的大, 修改一次的成本会十分昂贵!!!
我们使用一个Set接口实现, 已经发生了革命性的变化!
private UserDao userDao;
//利用set的动态实现值的注入
public void setUserDao(UserDao userDao) {
this.userDao = userDao;
}
控制反转:
之前, 是程序是主动创建对象, 控制权在程序员手上
使用了set注入后, 程序不在具有主动性, 而是变成了被动的接受对象! 控制权在用户手上
这种思想, 从本质上解决了问题, 我们程序员不用再去管理对象的创建了。系统的耦合性大大降低了, 可以更加专注在业务的实现上! 这就是IOC的原型
2.2、IOC的本质
控制反转Ioc(Inversion of Control) ,是一种设计思想, DI(依赖注入)是实现IoC的一种方法。没有IoC的程序中, 我们使用面向对象编程, 对象的创建与对象间的依赖关系完全硬编码在程序中, 对象的创建由程序自己控制, 控制反转后将对象的创建转移到第三方, 个人认为控制反转就是依赖的对象反转了
采用XML方式配置Bean时, Bean的定义信息是和实现分离的, 而采用注解的方式可以把两者合为一体, Bean定义信息直接以注解的形式定义在实现类中, 从而达到零配置的目的。
控制反转是一种通过描述(XML或者注解)并通过第三方去生产或获取的特定对象的方式。 在Spring中实现控制反转的是IoC容器, 其实现方法是依赖注入(Dependency Injection , DI)。
![image.png](https://img-blog.csdnimg.cn/img_convert/f01a29329cfee6393bc4c2fea2e5aee3.png#clientId=u9300e3bd-8338-4&from=paste&height=246&id=uc129ccc4&margin=[object Object]&name=image.png&originHeight=280&originWidth=884&originalType=binary&ratio=1&size=140018&status=done&style=none&taskId=u3dd79a76-4e2c-4f1c-bd41-0dcaf9d59bf&width=777)
IOC是Sping框架的核心内容, 使用多种方式完美的实现了IOC, 可以用XML配置, 也可以使用注解, 新版本的Spring也可以零配置实现IOC。
Spring容器在初始化读取配置文件, 根据配置文件或元数据创建与组织对象存入容器中, 程序使用是再从IOC容器取出需要的对象
![image.png](https://img-blog.csdnimg.cn/img_convert/fdf872febfb5231023aacc2b76e4515c.png#clientId=u9300e3bd-8338-4&from=paste&height=587&id=u314c8770&margin=[object Object]&name=image.png&originHeight=603&originWidth=744&originalType=binary&ratio=1&size=110499&status=done&style=none&taskId=ubc236129-1649-4de2-9734-7e86af500da&width=724)