Spring IoC理解记录来源知乎回答

发布于:2022-12-14 ⋅ 阅读:(1856) ⋅ 点赞:(2)

注明来源:

作者:Jackpop
链接:https://www.zhihu.com/question/53729800/answer/1217542529
来源:知乎
 

Spring

 IoC

假设一个场景:目前有三个角色,买水果的人(用户),卖水果的人(业务层),水果(持久化层),

先写一个接口,

public interface Fruit {
    public void get();
}

现在实现3种水果的类,为了方便展示,把它们先写在一起,

// Apple.java
public class Apple implements Fruit{
    public void get() {
        System.out.println("get an apple");
    }
}
​
// Orange.java
public class Banana implements Fruit{
    public void get() {
        System.out.println("get a banana");
    }
}
​
// Banana.java
public class Orange implements Fruit{
    public void get() {
        System.out.println("get a organe");
    }
}

现在实现一个业务层,也就是从3个水果类中获取水果,

// UserService.java
public class UserService {
    private Fruit fruit = new Apple();
    public void getFruit() {
        fruit.get();
    }
}

然后,实现一个用户类,

// User.java
public class User {
    public static void main(String[] args) {
        UserService user = new UserService();
        user.getFruit();
    }
}

然后,实现一个用户类,

// User.java
public class User {
    public static void main(String[] args) {
        UserService user = new UserService();
        user.getFruit();
    }
}

调用业务层UserService获取到苹果,那么试想一下,如果现在我想获取橘子怎么办?这样就需要修改业务层代码,

// UserService.java
public class UserService {
    private Fruit fruit = new Orange();
    public void getFruit() {
        fruit.get();
    }
}

也许很多同学会认为这样没什么问题,那就修改一下业务层代码啊?

显然,这不是一个优秀的程序员做的事情,每当用户需求做出改变时,我们的代码都要做出相应的修改,那么有两个问题,

  • 如果工程量较大,修改的内容较多怎么办?
  • 如果我们修改代码对其他业务造成影响怎么办?

所以,一个好的设计思路就应该在不改变原代码的基础上实现我们想要的功能。

那么,接下来就应该转变思维,考虑一下,目前的控制权在业务层,所以每次用户需求改变时,业务层也要跟着改变,既然这样,我们把控制权交给用户不就行了吗?

下面来修改一下业务层的代码实现控制权的转换,

public class UserService {
    private Fruit fruit;
    public void setFruit(Fruit fruit) {
        this.fruit = fruit;
    }
    public void getFruit() {
        this.fruit.get();
    }
}

细心的同学应该可以看得出改变,我在加了一个set方法,使得用户层可以注入不同的对象,这样我们在用户层传入哪个对象,就会获得哪个结果,

// 1. 获取橘子
public class User {
    public static void main(String[] args) {
        UserImpl user = new UserImpl();
        user.setFruit(new Orange());    //在这里注入对象
        user.getFruit();
    }
}
//2. 获取香蕉
public class User {
    public static void main(String[] args) {
        UserImpl user = new UserImpl();
        user.setFruit(new Banana());
        user.getFruit();
    }
}

上图展示的很明确,就是控制权的反转,之前主动权在业务层,每次用户提出需求业务层就需要跟着做出改变,现在我们把主动权交给了用户,它传进什么,就得到什么样的结果,这样业务代码就不用跟着改变了。

这就是IOC(控制反转)的核心思想。

控制反转IoC(Inversion of Control),是一种设计思想。


网站公告

今日签到

点亮在社区的每一天
去签到