spring框架IoC

IoC反转控制,

举个反例:

 1 //数据操作类
 2 public class DataBase
 3 {
 4     //向数据库中存储数据
 5     public void saveDB()
 6     {
 7     }
 8 }
 9 //业务逻辑类
10 public class Business
11 {
12     //定义数据接口
13     private DataBase db = new DataBase();
14     //数据保存
15     public void saveData()
16     {
17         //do something else
18         //保存数据
19         db.saveDB();
20     }
21 }
22 //现在修改为向XML文件保存
23 public class XMLData
24 {
25     //向xml中保存数据
26     public void saveXML()
27     {
28     }
29 }
30 //这个时候需要重新修改业务逻辑业务逻辑
31 public class Business
32 {
33     private XMLData xml = new XMLData();
34     //数据保存
35     public void saveData()
36     {
37         //do something esle
38         //保存数据
39         xml.saveXML();
40     }
41 }

可以看到 这种方法的不方便之处在于更改存储方式的时候,就需要更新全部的逻辑与方法

//定义一个接口
public interface SaveData()
{
    public void saveData();
}
//数据操作类
public class DataBase implements SaveData
{
    //向数据库中存储数据,实现接口的存储接口
    public void saveData()
    {
        //具体的向数据库中存入数据的逻辑
    }
}
//业务逻辑类
public class Business
{
    //定义数据接口
    private SaveData db;
    //定义数据保存类,这里传入的参数实际上是接口的子类,用顶级接口接收
    public void setSaveData(SaveData db)
    {
        //通过向上转型
        this.db = db;
    }
    public void saveData()
    {
        //do something
        this.db.saveData();
    }
}
//测试类
public class TestBusiness
{
    private Business b = new Business();
    public void saveData()
    {
        .....
        b.setSaveData(new DataBase());
    }
}

现在的好处就是使Business成为一个工厂,调用者无需关心底部存储的细节,只需要将存储方法设定到business,然后调用保存即可,而且这样一来

扩展也变得容易了,首先编写xml存储方法(继承savedata接口,并且实现存储方法),然后business无需更改,在业务逻辑传递进去xml存储对象即可.

可以看到,这样实现使得代码得到重用,而且增强了扩展性.

依赖注入:原本的方式是业务逻辑控制具体的存储方式,但是面向接口了以后,就不再业务逻辑里面编写具体的存储方式了,而是在调用业务逻辑的类里控制具体的存储方式,也就是上面的,由testbusiness调用业务逻辑的时候,控制了存储方式(原本是业务逻辑设定好存储方式然后供调用),看起来是由具体的存储方式控制了业务逻辑.

注入方式:

  1.set注入,也就是在business中定义一个私有的存储接口变量,然后定义set方法,注入具体的存储方式.

  2.接口注入,具体存储方式与存储接口还是一样,但是在业务逻辑中定义的是业务逻辑接口,然后在这个接口中定义了需要注入的信息(比如定义一个Disavedata(SaveData db)),然后每个业务逻辑都需要去继承这个接口,然后实现这个存储方法,在原本的set方法上,相当于保证了每个业务逻辑都有一个默认的注入方法(可以覆写).

  3,构造注入,跟set方法相比 只是把注入的逻辑放到了business的构造方法里面.

可以看到,无论是采用哪种方法,都需要使用面向接口编程

时间: 2024-10-01 04:58:53

spring框架IoC的相关文章

Spring框架IOC,DI概念理解

1.什么是框架? 框架是一种重复使用的解决方案,针对某个软件开发的问题提出的. Spring框架,它是一个大型的包含很多重复使用的某个领域的解决方案. Spring的理念:不要重复发明轮子. 2.Spring的理解? 首先,Spring是一个容器.它是装对象的.主要就是通过搜索class的路径.找出bean对象,实际就是根据反射来获取这个bean对象的: Class<?> classit=Class.forName("com.jinglin.model.Person");

Spring框架---IOC装配Bean

IOC装配Bean (1)Spring框架Bean实例化的方式提供了三种方式实例化Bean 构造方法实例化(默认无参数,用的最多) 静态工厂实例化 实例工厂实例化 下面先写这三种方法的applicationContext.xml配置文件: 1 <?xml version="1.0" encoding="UTF-8"?> 2 <beans xmlns="http://www.springframework.org/schema/beans&

Spring框架 IOC注解

Spring框架的IOC之注解方式的快速入门        1. 步骤一:导入注解开发所有需要的jar包        * 引入IOC容器必须的6个jar包        * 多引入一个:Spring框架的AOP的jar包,spring-aop的jar包        2. 步骤二:创建对应的包结构,编写Java的类        * UserService            -- 接口        * UserServiceImpl        -- 具体的实现类        3.

Spring框架IOC容器和AOP解析

主要分析点: 一.Spring开源框架的简介  二.Spring下IOC容器和DI(依赖注入Dependency injection) 三.Spring下面向切面编程(AOP)和事务管理配置  一.Spring开源框架的简介  Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson 在其著作Expert One-On-One J2EE Development and Design中阐述的部分理念和原型衍生而来.它是为了解决企业应用开

面试之Spring框架IOC和AOP的实现原理

IoC(Inversion of Control) (1). IoC(Inversion of Control)是指容器控制程序对象之间的关系,而不是传统实现中,由程序代码直接操控.控制权由应用代码中转到了外部容器,控制权的转移是所谓反转. 对于Spring而言,就是由Spring来控制对象的生命周期和对象之间的关系:IoC还有另外一个名字--"依赖注入(Dependency Injection)".从名字上理解,所谓依赖注入,即组件之间的依赖关系由容器在运行期决定,即由容器动态地将某

Spring框架—— IOC容器和Bean的配置

 1 IOC和DI ①IOC(Inversion of Control):反转控制. 在应用程序中的组件需要获取资源时,传统的方式是组件主动的从容器中获取所需要的资源,在这样的模式下开发人员往往需要知道在具体容器中特定资源的获取方式,增加了学习成本,同时降低了开发效率. 反转控制的思想完全颠覆了应用程序组件获取资源的传统方式:反转了资源的获取方向--改由容器主动的将资源推送给需要的组件,开发人员不需要知道容器是如何创建资源对象的,只需要提供接收资源的方式即可,极大的降低了学习成本,提高了开发的效

Spring框架IOC和AOP的实现原理

IoC(Inversion of Control) (1). IoC(Inversion of Control)是指容器控制程序对象之间的关系,而不是传统实现中,由程序代码直接操控.控制权由应用代码中转到了外部容器,控制权的转移是所谓反转. 对于Spring而言,就是由Spring来控制对象的生命周期和对象之间的关系:IoC还有另外一个名字--"依赖注入(Dependency Injection)".从名字上理解,所谓依赖注入,即组件之间的依赖关系由容器在运行期决定,即由容器动态地将某

Spring框架IOC解说

控制反转——Spring通过一种称作控制反转(IoC)的技术促进了松耦合.当应用了IoC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创建或者查找依赖对象.你可以认为IoC与JNDI相反——不是对象从容器中查找依赖,而是容器在对象初始化时不等对象请求就主动将依赖传递给它. 好吧,那我们从简单的说起.直接讲概念有点抽象,让我们从一个实际的场景来分析这个事情.大毛想要找个女朋友,他的朋友二毛帮忙介绍了一个女生,叫翠花.然后大毛跟翠花认识了.相处了一段时间,因为翠花要大毛和他一起

spring框架IOC设值注入

spring以动态的形式来管理对象,注入分为两种: 1. 设置注入:直观  自然 2.构造注入:可以在构造器中决定依赖顺序 以下就是示例: 1.User实体类 package com.domain; import java.io.Serializable; /** * * @author Mr * 实体类 */ public class User implements Serializable { private Integer id; private String uname; private