Inversion of Control, 翻译为 “控制反转”, 它还有一个别名为 DI(Dependency Injection), 即依赖注入。
在传统的开发模式下,我们都是在自己对象中主动去创建被依赖的对象,这是正转。有了IOC之后,所依赖的对象直接由 IoC 容器创建后注入到被注入的对象中,依赖的对象由原来的主动获取变成被动接受,所以是反转。更简单地说,就是"获得依赖对象的过程被反转了"。
"依赖注入"是"控制反转"的另一个别名。所谓依赖注入,就是由IOC容器在运行期间,动态地将某种依赖关系注入到对象之中。
依赖注入的三种实现形式:
1.构造器注入
构造器注入,就是被注入的对象通过在其构造方法中声明依赖对象的参数列表,让外部知道它需要哪些依赖对象
public class FoodFactory { private WorkerDao workerDao = null; FoodFactory(WorkerDao workerDao) { this.workerDao = workerDao; } /** * 其他业务 */ }
2.setter 方法注入
对于 JavaBean 对象而言,我们一般都是通过 getter 和 setter 方法来访问和设置对象的属性。所以,当前对象只需要为其所依赖的对象提供相对应的 setter 方法,就可以通过该方法将相应的依赖对象设置到被注入对象中。
public class FoodFactory { private WorkerDao workerDao = null; public void setFoodFactory(WorkerDao workerDao) { this.workerDao = workerDao; } /** * 其他业务 */ }
3.接口注入(Interface Injection)
接口方式注入,显得比较霸道,因为它需要被依赖的对象实现不必要的接口,带有侵入性。一般都不推荐这种方式。
public class WorkerDao { public String doWork(){ System.out.println("work..........."); return "ok"; } }
public interface InjectWorkerDao { void setWorkerDao(WorkerDao workerDao); }
public class FoodFactory implements InjectWorkerDao{ private WorkerDao workerDao = null; @Override public void setWorkerDao(WorkerDao workerDao) { this.workerDao = workerDao; } /** * 其他业务 */ }