Android RoboGuice 使用指南(10): Just-in-time Bindings

Injector 通过检查bindings 定义来创建某个类型的实例对象。定义在Module中的绑定称为“明确声明绑定(Explicit bindings”。Injector 会首先使用带有Explicit Bindings为某个类型创建实例对象。 当但某个类型没有明确定义绑定时,Injector 试图构造“即时绑定(Just-in-time Bindings),JIT Bindings 也成为隐含绑定(implicit bindings).

Eligible Constructor

Injector 通过使用类的injectable constructor 来创建该类的实例对象。injectable constructor 可以为该类定义的public 不带参数的构造函数或是带有@Injector 标记的构造函数。

比如Android RoboGuice 使用指南(4):Linked Bindings中MyRectangle的无参数构造函数:

public class MyRectangle extends Rectangle{
 public MyRectangle(){
 super(50,50,100,120);
 }
 ...
}

Android RoboGuice 使用指南(6):Instance Bindings 定义的含@Injector 标记的构造函数:

public class MySquare extends MyRectangle {
 @Inject public MySquare(@Named("width") int width){
 super(width,width);
 }
}

 

@ImplementedBy
 
该标记通知Injector某个类型的缺省实现,其功能和Linked Bindings 类似,例如:

 

@ImplementedBy(PayPalCreditCardProcessor.class)
public interface CreditCardProcessor {
 ChargeResult charge(String amount, CreditCard creditCard)
 throws UnreachableException; }

 

bind(CreditCardProcessor.class) .to(PayPalCreditCardProcessor.class);

 

等效。 如果某个类型同时含有@ImplementedBy 和bind 定义,将优先使用bind 中的定义。

注: @ImplementedBy 定义了从Interface到实现的依赖,一般不建议使用。

@ProvidedBy

@ProvidedBy 通知Injector 某个类型使用那个缺省Provider来创建实例对象,例如:

@ProvidedBy(DatabaseTransactionLogProvider.class)
public interface TransactionLog {
 void logConnectException(UnreachableException e);
 void logChargeResult(ChargeResult result);
}

和下面Binding等效:

bind(TransactionLog.class)
 .toProvider(DatabaseTransactionLogProvider.class);

 

 和@ImplementedBy 一样,如果同时定义了@ProvidedBy和bind,模块中定义的bind 优先

发表评论

邮箱地址不会被公开。 必填项已用*标注

昵称 *