DI——Dependency Injection 依赖注入
IoC——Inversion of Control 控制反转
Container 容器
要想理解DI和IoC概念,就必须搞清楚如下的问题:
1、参与者都有谁?
答:一般有三方参与者,一个是某个对象;一个是IoC/DI的容器;另一个是某个对象的外部资源。又要名词解释一下,某个对象指的就是任意的、普通的Java/PHP对象; IoC/DI的容器简单点说就是指用来实现IoC/DI功能的一个框架程序;对象的外部资源指的就是对象需要的,但是是从对象外部获取的,都统称资源,比如:对象需要的其它对象、或者是对象需要的文件资源等等。
2、依赖:谁依赖于谁?为什么会有依赖?
答:某个对象依赖于IoC/DI的容器。依赖是不可避免的,在一个项目中,各个类之间有各种各样的关系,不可能全部完全独立,这就形成了依赖。传统的开发是使用其他类时直接调用,这会形成强耦合,这是要避免的。依赖注入借用容器转移了被依赖对象实现解耦。
3、注入:谁注入于谁?到底注入什么?
答:通过容器向对象注入其所需要的外部资源
4、控制反转:谁控制谁?控制什么?为什么叫反转?
答: IoC/DI的容器控制对象,主要是控制对象实例的创建。反转是相对于正向而言的,那么什么算是正向的呢?考虑一下常规情况下的应用程序,如果要在A里面使用C,你会怎么做呢?当然是直接去创建C的对象,也就是说,是在A类中主动去获取所需要的外部资源C,这种情况被称为正向的。那么什么是反向呢?就是A类不再主动去获取C,而是被动等待,等待IoC/DI的容器获取一个C的实例,然后反向的注入到A类中。
5、依赖注入和控制反转是同一概念吗?
答:从上面可以看出:依赖注入是从应用程序的角度在描述,可以把依赖注入描述完整点:应用程序依赖容器创建并注入它所需要的外部资源;而控制反转是从容器的角度在描述,描述完整点:容器控制应用程序,由容器反向的向应用程序注入应用程序所需要的外部资源。
简单的理解:
啥是依赖/依赖注入/控制反转/反射 ?
-
依赖 :不能直接操作需要别人才能完成
举例:到餐馆吃饭得厨师给你菜炒好,才能吃
-
依赖注入:依赖注入是指将组件的依赖通过外部以参数或其他形式注入
举例:到餐馆吃饭自带酒水
-
控制反转:控制反转是将组件间的依赖关系从程序内部提到外部来管理
举例:到餐馆吃饭之前吃的套餐,菜是厨师定的,换成点菜,吃啥自己说了算
-
反射:直观理解就是根据到达地找到出发地和来源
举例:有点像摸烤鸭屁股就知道是哪里的鸭子的笑话一样
参考文章: