【Android】Dagger的简单使用

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的使用就完成了。


版权声明:本文为qq_23049111原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。