Spring的核心与设计思想
目录
IoC
传统程序开发思想
传统程序开发的缺陷
控制反转式程序开发
对比总结
理解Spring IoC
DI
总结
我们通常所说的Spring指的是Spring Framework(Spring 框架),它是一个开源的框架,有着活跃而庞大的社区,Spring支持广泛的应用场景,可以让Java企业级的应用程序开发起来更加简单高效.
一句话概括Spring:Spring是包含了众多工具方法的IoC容器.
理解这句话,我们需要明白什么是IoC,什么是容器.
容器就是用来容纳某种物品的基本装置,我们之前也接触过容器,像List,Map是数据存储的容器,Tomcat就是Web容器.
IoC
IoC = Inversion of Control,控制反转.也就是说Spring是一个控制反转的容器.
我们举一个例子来深刻理解"控制反转":
我们用程序来构建一辆车,汽车依赖于车身,车身依赖于底盘,底盘依赖于轮胎.
传统程序开发思想
传统的思想构建一辆车,我们是从上往下,依靠着彼此之间的依赖关系逐层实现.
代码:
public class NewCarExample {public static void main(String[] args) {Car car = new Car();car.init();}//汽车对象static class Car{public void init(){System.out.println("do car");//依赖车身Framework framework = new Framework();framework.init();}}static class Framework{//依赖底盘public void init(){System.out.println("do framework");Bottom bottom = new Bottom();bottom.init();}}static class Bottom{public void init(){//依赖轮胎System.out.println("do bottom");Tire tire = new Tire();tire.init();}}static class Tire{//尺寸private int size = 17;public void init(){System.out.println("轮胎尺寸: " + size);}}}
传统程序开发的缺陷
以上程序中,轮胎的尺⼨的固定的,然⽽随着对的⻋的需求量越来越⼤,个性化需求也会越来越多,这 时候我们就需要加⼯多种尺⼨的轮胎,那这个时候就要对上⾯的程序进⾏修改.
public class NewCarUpdateExample {public static void main(String[] args) {Car car = new Car(20);car.run();}static class Car {private Framework framework;public Car(int size) {framework = new Framework(size);}public void run() {// 依赖⻋身System.out.println("do car");framework.init();}}static class Framework {private Bottom bottom;public Framework(int size) {bottom = new Bottom(size);}public void init() {// 依赖底盘System.out.println("do framework");bottom.init();}}static class Bottom {private Tire tire;public Bottom(int size) {tire = new Tire(size);}public void init() {// 依赖轮胎System.out.println("do bottom");tire.init();}}static class Tire {// 尺⼨private int size;public Tire(int size) {this.size = size;}public void init() {System.out.println("轮胎尺⼨:" + size);}}
}
从上述例子中不难看出传统设计思想设计出来的程序的问题,当最底层的代码改动之后,整个调用链上的所有代码都需要修改.
解决上述问题,我们只需要将原来自己创建的下级类,改为传递注入的方式,因为我们不需要再当前类中创建下级类了,所以即使下级类发生改变,当前类本身也无需修改任何代码,这就实现了程序的解耦.
控制反转式程序开发
把创建子类的方式,改为传递注入的方式.
public class IoCCarExample {public static void main(String[] args) {Tire tire = new Tire(15);Bottom bottom =new Bottom(tire);Framework framework = new Framework(bottom);Car car = new Car(framework);car.run();}static class Car{private Framework framework;public Car(Framework framework){this.framework = framework;}public void run(){System.out.println("do car");framework.init();}}static class Framework{private Bottom bottom;public Framework(Bottom bottom){this.bottom = bottom;}public void init(){System.out.println("do framework");bottom.init();}}static class Bottom{private Tire tire;public Bottom(Tire tire){this.tire = tire;}public void init(){System.out.println("do bottom");tire.init();}}static class Tire{private int size = 20;public Tire(int size){this.size = size;}public void init(){System.out.println("轮胎尺寸: " + size);}}
}
代码经过上述调整之后,无论底层如何变化,整个调用链是用做任何的改变的,这样就完成了代码之间的解耦.
对比总结
传统new对象的方式类的创建顺序:
Car ->Framework->Bottom->Tire
IoC类的创建顺序:
Tire->Bottom->Framework->Car
这就发生了控制权的反转,不再是上级对象创建并控制下级对象了,而是把下级对象注入到当前对象当中,下级的控制权不再是是由上机控制了,这样即使下级类发生变化,上级类都是不受影响的,这就是典型的控制反转,也是IoC的实现思想.
IoC不是一个技术,而是一种思想.
理解Spring IoC
Spring是IoC容器,是一个容器那就意味着它具备着两个最基础的功能:将对象存入容器和从容器中取出对象.
学Spring最核心的功能就是学如何把对象从存入到Spring中,再从Spring中获取对象的过程.
Spring是一个IoC容器,就说明了对象的创建和销毁都交给Spring来管理了,它本身又具备了存储对象和获取对象的能力.
将对象放到容器中的好处
将对象存储在 IoC 容器相当于将以后可能⽤的所有⼯具制作好都放到仓库中,需要的时候直接取就⾏了,⽤完再把它放回到仓库。⽽ new 对象的⽅式相当于,每次需要⼯具了,才现做,⽤完就扔掉了也不会保存,下次再⽤的时候还得重新做,这就是 IoC 容器和普通程序开发的区别。
Spring IoC的优点
1.解耦
2.使用更加方便(不再需要手动创建,和关注这个对象背后的依赖关系)
3.更加高效
DI
DI是Dependency Injection的缩写,翻译成中文就是"依赖注入"的意思.
依赖注入:由IoC容器在运行期间,动态的将某种依赖关系注入到对象之中.(将依赖的某个对象注入到当前类中的行为就叫做依赖注入)
所以依赖注入(DI)和控制反转(IoC)是从不同的角度描述的同一件事情,就是指通过IoC容器,利用依赖关系注入的方式,实现对象之间的解耦.
IoC是目标也是一种思想,而目标和思想只是一种指导原则,最终还是要有可行的落地方案,而DI就是具体的实现.
前面所写的IoC控制反转的程序是通过传递的方式实现,这是被动的,DI(依赖注入)这是主动的(主动获取对象).
两种不同的实现技术都可以实现IoC思想,而Spring IoC是一个框架,这个框架的实现是通过DI.
总结
Spring是什么?如何理解Spring?
Spring是一个非常流行的开源框架,核心就是包含了众多工具方法的IoC容器,既然说 是一个IoC容器,就包含了两个最基本的操作,将bean对象存储到容器当中,从容器当中取出bean对象.
IoC和DI是什么?有什么区别?
IoC 控制反转,DI 依赖注入.
IoC和DI是从不同的角度描述的是同一件事情,区别就是IoC是一个思想,DI是具体的实现.
Spring最核心的功能?
IoC容器,IoC容器最基础的操作有两个,存bean取bean.