SPRING 依赖注入机制(反转控制)解析 Spring 能有效地组织J2EE 应用各层的对象
不管是控制层的Action 对象,还是业务层的 Service对象,还是持久层的DAO 对象,都可在Spring 的管理下有机地协调、运行
Spring 将各层的对象以松耦合的方式组织在一起,Action 对象无须关心 Service 对象的具体实现,Service 对象无须关心持久层对象的具体实现,各层对象的调用完全面向接口
当系统需要重构时,代码的改写量将大大减少
上面所说的一切都得宜于 Spring 的核心机制,依赖注入
依赖注入让 bean 与 bean 之间以配置文件组织在一起,而不是以硬编码的方式耦合在一起
理解依赖注入 依赖注入(Dependency Injection)和控制反转(Inversion of Control)是同一个概念
具体含义是:当某个角色(可能是一个 Java 实例,调用者)需要另一个角色(另一个 Java 实例,被调用者)的协助时,在传统的程序设计过程中,通常由调用者来创建被调用者的实例
但在Spring 里,创建被调用者的工作不再由调用者来完成,因此称为控制反转;创建被调用者实例的工作通常由 Spring 容器来完成,然后注入调用者,因此也称为依赖注入
不管是依赖注入,还是控制反转,都说明 Spring 采用动态、灵活的方式来管理各种对象
对象与对象之间的具体实现互相透明
在理解依赖注入之前,看如下这个问题在各种社会形态里如何解决:一个人(Java 实例,调用者)需要一把斧子(Java 实例,被调用者)
(1)原始社会里,几乎没有社会分工
需要斧子的人(调用者)只能自己去磨一把斧子(被调用者)
对应的情形为:Java 程序里的调用者自己创建被调用者
(2)进入工业社会,工厂出现
斧子不再由普通人完成,而在工厂里被生产出来,此时需要斧