Spring 依赖注入 ---使用的必要性

Spring 依赖注入 —使用的必要性

刚开始学Spring, 不太清楚使用Spring的必要性,于是乎在知乎上看大牛们怎样解释,找到以下通俗易懂的解释。

作者:Ziphwy
链接:https://www.zhihu.com/question/27053548/answer/85060703
来源:知乎
著作权归作者所有,转载请联系作者获得授权。

假如我们要实现一个存款的应用,那么,我们的思维是这么走的:
1.写一个“存款类”,里面有“存款方法”,“存款方法”直接操作数据库实现存款逻辑。

2.你突然发现,操作数据库的方法都是增删查改,为什么不写成一个类,让“存款方法”去调用这个操作数据库的类,减少了不少重复代码。
(分层思想来了,业务逻辑和数据操作分离了)

3.你的朋友知道了你在写这个应用,就跟你提意见,不如我帮你写操作数据库的类,你写存款业务的类,这样不就快了吗?我们约定一个接口,你调用这个接口,我实现这个接口,这样开发就很快了。
(接口思想来了,调用方不必理会具体实现,专注于自己的逻辑)(工厂模式)

4.你在写你的业务逻辑的时候,发现虽然你不用管数据操作逻辑的实现,但是在你的代码了,创建一个对象的语法:
接口 变量名 = new 实现类();
在做了那么多分离工作,还是要写new 实现类();,还是依赖于实现类。你就想,能不能做一个容器,自动帮我将实现类赋给接口呢?(依赖注入思想)
于是,你写出了spring,一开始使用xml配置,在类里面只需要getBean(),接口和实现类和调用类基本分离了(松耦合形成了),后来xml你也懒得写,弄出一批注解,实现类注解一下是组件,调用类声明一个接口,写个@AutoWired,spring容器就帮你完成了将实现类赋给接口的工作,即所谓的spring帮你new了一个对象。

最后你的应用结构如下图:

比起刚开始一个类里面参杂着各式各样的代码,现在看一个个部件似的,何等舒服!

注:spring不止是DI,还有AOP,MVC等等,依赖注入只是它的一个功能。

// 旧答案
举个例子,比如你写
Apple apple = new Apple();
People people = new People();
people.eat(apple);

然后有一天,客户说不想吃Apple了
给我改成吃Orange,然后你打开源文件

Orange orange = new Orange();
People people = new People();
people.eat(orange);
再重新编译

再一天,客户又觉得不好,要Peach了

Peach peach = new Peach();
People people = new People();
people.eat(peach);
再重新编译

………

然后你在客户的需求下崩溃了

倘若您用spring

Fruit fruit = (Fruit)beanFactory.getBean(“fruit”);

People people = (People)beanFactory.getBean(“people”);

people.eat(fruit);

这样使用了接口Fruit,你只需要在xml文件配置,更换fruit的bean,无需改变源代码。对于people也如此。

会发现,我们在这种设计下会少维护了很多代码,达到这样的效果的原因是因为,Fruit和People没有参杂在一起,没有谁调用了谁等等,实际上就是没有耦合,他们的关系由接口代替表示了。

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值