IOC = inverse of control 控制反转。控制反转是靠反射来动态生成对象,注入依赖关系的。让代码更加灵活。
1. http://www.qqread.com/erp/3/j380307_2.html
2.http://m-ittrue.iteye.com/blog/829744
构造注入
public class MoAttack{ private GeLi geli; public MoAttack(GeLi geli){ ① 注入革离的具体扮演者 this.geli = geli; } public void cityGateAsk() { geli.responseAsk(“墨者革离!”); } }
MoAttack的构造函数不关心具体是谁扮演革离这个角色,只要在①处传入的扮演者按剧本要求完成角色功能即可。 角色的具体扮演者由导演来安排,如代码清单 3 4所示: 代码清单 4 Director:通过构造函数注入革离扮演者 public class Director{ public void direct(){ GeLi geli = new LiuDeHua(); ① 指定角色的扮演者 MoAttack moAttack = new MoAttack(geli); ② 注入具体扮演者到剧本中 moAttack.cityGateAsk(); } }
在①处,导演安排刘德华饰演革离的角色,并在②处,将刘德华“注入”到墨攻的剧本中,然后开始“城门问答”剧段的演出工作。
setter注入
MoAttack在①处为geli属性提供一个setter方法,以便让导演在拍需要革离的戏时才将注入geli的具体扮演者,而不需要刘德华从头到尾跟着墨攻剧组跑。 代码清单 6 Director:通过setter方法注入革离扮演者 public class Director ...{ public void direct()...{ GeLi geli = new LiuDeHua(); MoAttack moAttack = new MoAttack(); moAttack.setGeli(geli); ① 调用属性setter方法注入 moAttack.cityGateAsk(); } }
和通过构造函数注入革离扮演者不同,在实例化MoAttack时,并未指定任何扮演者,而是在实例化MoAttack后,调用其setGeli()方法注入扮演者。按照类似的方式,我们还可以为剧本中其他如巷淹中,梁王等角色分别提供注入的setter方法,导演即可以根据所拍剧段的不同,注入所需要的角色了。
将客户类所有注入的方法抽取到一个接口中,客户类通过实现这一接口提供注入的方法。为了采取接口注入的方式,需要声明一个额外的接口: public interface ActorArrangable ...{ void injectGeli(GeLi geli); } 然后,MoAttack实现这个接口并实现接口中的方法: 代码清单 7 MoAttack:通过接口方法注入革离扮演者 public class MoAttack implements ActorArrangable ...{ private GeLi geli; public void injectGeli (GeLi geli) ...{ ① 实现接口方法 this.geli = geli; } public void cityGateAsk() ...{ geli.responseAsk("墨者革离"); } } Director通过ActorArrangable的injectGeli()方法完成扮演者的注入工作。 代码清单 8 Director:通过接口方法注入革离扮演者 public class Director ...{ public void direct()...{ GeLi geli = new LiuDeHua(); MoAttack moAttack = new MoAttack(); moAttack. injectGeli (geli); moAttack.cityGateAsk(); } } 由于通过接口注入需要额外声明一个接口,增加了类的数目,而且它的效果和属性注入并无本质区别,因此我们不提倡这种方式。
接口注入--spring没用这个 感觉跟setter注入很像