Dagger是goole提供的一款依赖注入框架,目的在于项目解耦,提高项目的灵活性。
下面仅使用两个注解@Inject和@Component来入门Dagger。
首先添加依赖
compile 'com.google.dagger:dagger:2.23.2' annotationProcessor 'com.google.dagger:dagger-compiler:2.23.2'
现在有两个类Engine和Car:
public class Engine {
public Engine() {
}
}
public class Car {
private Engine engine;
public Car(Engine engine) {
this.engine = engine;
}
}
获得一个Car实例的常规做法是:
Engine engine = new Engine();
Car car = new Car(engine);
如果使用Dagger注入,首先给Engine的构造方法添加Inject注解,告诉Dagger框架,Engine支持注入。
public class Engine {
@Inject
public Engine() {
}
}
然后在Car的构造方法上也添加Inject注解,告诉Dagger,Car支持注入。
public class Car {
private Engine engine;
@Inject
public Car(Engine engine) {
this.engine = engine;
}
}
最后增加一个接口,并用Component注解,我们通过这个接口获取Dagger提供的Car实例:
@Component
public interface CarComponent {
Car car();
}
build一下项目,Dagger会自动生成一个前缀是Dagger的类DaggerCarComponent,使用这个类获取Car实例:
Car car = DaggerCarComponent.create().car();
一次最简单的Dagger的使用就完成了。