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)。

IOC是Sping框架的核心内容, 使用多种方式完美的实现了IOC, 可以用XML配置, 也可以使用注解, 新版本的Spring也可以零配置实现IOC。
Spring容器在初始化读取配置文件, 根据配置文件或元数据创建与组织对象存入容器中, 程序使用是再从IOC容器取出需要的对象

本文深入浅出地介绍了IOC(控制反转)的概念及其在软件开发中的重要性,探讨了依赖注入(DI)作为实现IOC的一种方法,并解释了如何通过XML配置和注解来降低系统的耦合度。
176万+

被折叠的 条评论
为什么被折叠?



