Spring-02-IOC理论推导

本文探讨了Spring框架中的IOC(控制反转)原理,通过一个具体的例子展示了如何从手动管理对象到使用依赖注入降低耦合。在改进前,程序员需要修改代码以适应用户需求,这违反了开闭原则。通过引入IOC,程序员只需关注新增实现类,用户则可以通过设置注入选择所需实现。总结了IOC如何通过依赖注入实现控制反转,并提到了XML配置和注解两种方式。
摘要由CSDN通过智能技术生成

Spring-02-IOC理论推导

IOC的原型

使用以前的方式

Dao层

创建UserDao接口

public interface UserDao {
    void getUser();
}

创建UserDaoImpl实现类

public class UserDaoImpl implements UserDao{
    public void getUser() {
        System.out.println("使用默认的方式获取用户");
    }
}

Service层

创建UserService接口

public class UserServiceImpl implements UserService{

    //由程序员创建实例对象
    private UserDao userDao = new UserDaoImpl();

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

创建UserServiceImpl实现类

测试

public class MyTest {
    public static void main(String[] args) {
        UserService userService = new UserServiceImpl();
        userService.getUser();
    }
}
//使用默认的方式获取用户

现在用户提出新的需求,需要使用mysql获取用户(模拟)

程序员:

  • 新增Dao层UserDaoMysqlImpl实现类

    public class UserDaoMysqlImpl implements UserDao{
        public void getUser() {
            System.out.println("使用mysql获取用户!");
        }
    }
    
  • 修改Service层的实现类

    public class UserServiceImpl implements UserService{
        //由程序员创建实例对象,这里将默认的实现类修改为Mysql的实现类
        private UserDao userDao = new UserDaoMysqlImpl();
    
        public void getUser() {
            userDao.getUser();
        }
    }
    

在本例中,很明显

用户一有新的需求,程序员除了新增Dao层,还要修改Service代码

这违背了开闭原则(对扩展开放,对修改关闭)

同时如果代码量十分巨大,一一修改的成本是高昂的

避免此类情况

改进UserServiceImpl实现类

public class UserServiceImpl implements UserService{

    //给用户选择 具体实现类的入口,将控制权交给用户,不再由程序员控制具体实现类
    private UserDao userDao;
    public void setUserDao(UserDao userDao) {
        this.userDao = userDao;
    }

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

测试

public class MyTest {
    public static void main(String[] args) {
        UserServiceImpl userService = new UserServiceImpl();
        //用户在这里控制自己想要的实现类
        userService.setUserDao(new UserDaoMysqlImpl());
        userService.getUser();
    }
}

总结

在改进前,程序大部分的主动权在程序员手上

在使用set注入改进后,程序的部分主动权让渡给了用户,而这大大降低了程序的耦合

这种思想从本质上解决了问题,程序员只要考虑根据用户需求新增dao实现类即可,而不用去修改源代码

IOC本质

控制反转IoC(Inversion of Control),是一种设计思想,DI(依赖注入)是实现IoC的一种方法,而在上例中,在没有IoC的情况下,使用面向对象编程,对象的创建和对象之间的依赖关系完全硬编码在程序中,对象的创建由程序员自己控制,控制反转后,将对象的创建转移给第三方了
采用XML方式配置Bean时,Bean的定义信息和实现是分离的,而采用注解的方式额可以将二者合二为一,Bean的定义信息直接以注解的形式定义在实现类中,从而达到了零配置的目的
控制反转是一种通过描述(XML或注解)并通过第三方去生产或获取特定对象的方式,在Spring中实现控制反转的是IoC容器,其实现方法是依赖注入(Dependency injection,DI).
Spring-IOCSpring框架的核心部分之一,它是一种设计模式,全称为Inversion of Control(控制反转)。它通过将对象的创建、依赖关系的管理和对象的生命周期交给Spring容器来实现,从而降低了组件之间的耦合度,提高了代码的可重用性和可维护性。Spring-IOC的实现主要依靠Spring容器,Spring容器是Spring框架的核心,它负责创建、管理和装配Bean对象,其中Bean是Spring框架中最基本的组件。 Spring-IOC的实现主要有两种方式:BeanFactory和ApplicationContext。其中,BeanFactory是Spring-IOC的基本实现,而ApplicationContext是BeanFactory的子接口,提供了更多高级特性。ApplicationContext是Spring框架中最常用的IOC容器,它除了提供BeanFactory的所有功能外,还提供了更多的企业级特性,例如AOP、事务管理、国际化、事件传播等。 下面是一个简单的Spring-IOC的例子,假设我们有一个UserService接口和一个UserServiceImpl实现类,我们可以通过Spring-IOC容器来创建和管理UserServiceImpl对象: 1.定义UserService接口和UserServiceImpl实现类 ```java public interface UserService { void addUser(User user); } @Service public class UserServiceImpl implements UserService { @Override public void addUser(User user) { // 添加用户的具体实现 } } ``` 2.在Spring配置文件中配置UserService实例 ```xml <bean id="userService" class="com.example.service.UserServiceImpl"/> ``` 3.在代码中获取UserService实例并使用 ```java ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml"); UserService userService = context.getBean("userService", UserService.class); User user = new User(); userService.addUser(user); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值