Spring之IOC思想


IOC 控制反转

DAO层

UserDao 接口

public interface UserDao {
    public void getUser();
}

UserDaoImpl 实现

public class UserDaoImpl implements UserDao {
    @Override
    public void getUser() {
        System.out.println("默认获取User");
    }
}

Service层

UserService 接口

public interface UserService {
    void getUser();
}

UserServiceImpl 实现

public class UserServiceImpl implements UserService {

    UserDao userDao = new UserDaoImpl();

    @Override
    public void getUser() {
        userDao.getUser();
    }
}

测试

public class MyTest {

    @Test
    public void getUser(){

        //用户实际调用的是业务层Service,dao层他们不需要接触
        UserServiceImpl userService = new UserServiceImpl();
        userService.getUser();
    }
}

IOC 运用后


当dao层的实现变得十分庞大的时候,需要程序员手动修改代码以满足用户需求,维护代价极高!

因此,引入 set 进行动态值的注入。

例:当DAO层的实现类除了 UserDaoImpl 的实现,还新增了以下实现:

添加了DAO层实现

UserDaoMysqlImpl 实现

public class UserDaoMysqlImpl implements UserDao {
    @Override
    public void getUser() {
        System.out.println("mysql");
    }
}

userDaoOracleImpl 实现

public class userDaoOracleImpl implements UserDao {
    @Override
    public void getUser() {
        System.out.println("oracle!");
    }
}

修改service层代码

由于用户实际调用的是service层,因此,只需要修改service层代码进行动态注入即可。

public class UserServiceImpl implements UserService {

    private UserDao userDao;
    //使用set进行动态值的注入
    public void setUserDao(UserDao userDao) {
        this.userDao = userDao;
    }

    @Override
    public void getUser() {
        userDao.getUser();
    }
}

测试

public class MyTest {

    @Test
    public void getUser(){

        //用户实际调用的是业务层Service,dao层他们不需要接触
        UserServiceImpl userService = new UserServiceImpl();
        //用户可以自己选择具体实现dao层
        userService.setUserDao(new UserDaoMysqlImpl());

        userService.getUser();
    }
}

以前所有东西都是由程序去进行控制创建 , 而现在是由我们自行控制创建对象 , 把主动权交给了调用者 . 程序不用去管怎么创建,怎么实现了 . 它只负责提供一个接口 .

这种思想 , 从本质上解决了问题 , 我们程序员不再去管理对象的创建了 , 更多的去关注业务的实现 . 耦合性大大降低 . 这也就是IOC的原型 !


IOC本质

控制反转IoC(Inversion of Control),是一种设计思想,DI(依赖注入)是实现IoC的一种方法,也有人认为DI只是IoC的另一种说法。没有IoC的程序中 , 我们使用面向对象编程 , 对象的创建与对象间的依赖关系完全硬编码在程序中,对象的创建由程序自己控制,控制反转后将对象的创建转移给第三方,个人认为所谓控制反转就是:获得依赖对象的方式反转了。

image

IoC是Spring框架的核心内容,使用多种方式完美的实现了IoC,可以使用XML配置,也可以使用注解,新版本的Spring也可以零配置实现IoC。

Spring容器在初始化时先读取配置文件,根据配置文件或元数据创建与组织对象存入容器中,程序使用时再从Ioc容器中取出需要的对象。

采用XML方式配置Bean的时候,Bean的定义信息是和实现分离的,而采用注解的方式可以把两者合为一体,Bean的定义信息直接以注解的形式定义在实现类中,从而达到了零配置的目的。

控制反转是一种通过描述(XML或注解)并通过第三方去生产或获取特定对象的方式。在Spring中实现控制反转的是IoC容器,其实现方法是依赖注入(Dependency Injection,DI)


文章作者: Hailong Gao
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 Hailong Gao !
评论
  目录