Dependências de componentes - use isso quando desejar manter dois componentes independentes.
Subcomponentes - use-o quando desejar manter dois componentes acoplados.
Usarei o exemplo abaixo para explicar dependências e subcomponentes de componentes . Alguns pontos dignos de nota sobre o exemplo são:
SomeClassA1pode ser criado sem qualquer dependência. ModuleAfornece e instância de SomeClassA1via o provideSomeClassA1()método
SomeClassB1não pode ser criado sem SomeClassA1. ModuleBpode fornecer uma instância de SomeClassB1somente se uma instância de SomeClassA1for passada como um argumento para o provideSomeClassB1()método
@Module
public class ModuleA {
@Provides
public SomeClassA1 provideSomeClassA1() {
return new SomeClassA1();
}
}
@Module
public class ModuleB {
@Provides
public SomeClassB1 provideSomeClassB1(SomeClassA1 someClassA1) {
return new SomeClassB1(someClassA1);
}
}
public class SomeClassA1 {
public SomeClassA1() {}
}
public class SomeClassB1 {
private SomeClassA1 someClassA1;
public SomeClassB1(SomeClassA1 someClassA1) {
this.someClassA1 = someClassA1;
}
}
O Dagger cuidará de passar a instância de SomeClassA1como um argumento para o provideSomeClassB1()método ModuleBsempre que a declaração de Componente / Subcomponente ModuleBfor inicializada. Precisamos instruir Dagger como cumprir a dependência. Isso pode ser feito usando dependência de componente ou subcomponente .
Dependência de componentes
Observe os seguintes pontos no exemplo de dependência de componente abaixo:
ComponentBdeve definir a dependência através do dependenciesmétodo na @Componentanotação.
ComponentAnão precisa declarar ModuleB. Isso mantém os dois componentes independentes.
public class ComponentDependency {
@Component(modules = ModuleA.class)
public interface ComponentA {
SomeClassA1 someClassA1();
}
@Component(modules = ModuleB.class, dependencies = ComponentA.class)
public interface ComponentB {
SomeClassB1 someClassB1();
}
public static void main(String[] args) {
ModuleA moduleA = new ModuleA();
ComponentA componentA = DaggerComponentDependency_ComponentA.builder()
.moduleA(moduleA)
.build();
ModuleB moduleB = new ModuleB();
ComponentB componentB = DaggerComponentDependency_ComponentB.builder()
.moduleB(moduleB)
.componentA(componentA)
.build();
}
}
SubComponent
Observe os seguintes pontos no exemplo SubComponent:
- Como
ComponentBnão definiu a dependência ModuleA, ela não pode viver de forma independente. Torna-se dependente do componente que fornecerá o ModuleA. Por isso, tem uma @Subcomponentanotação.
ComponentAdeclarou ModuleBatravés do método de interface componentB(). Isso torna os dois componentes acoplados. De fato, ComponentBsó pode ser inicializado via ComponentA.
public class SubComponent {
@Component(modules = ModuleA.class)
public interface ComponentA {
ComponentB componentB(ModuleB moduleB);
}
@Subcomponent(modules = ModuleB.class)
public interface ComponentB {
SomeClassB1 someClassB1();
}
public static void main(String[] args) {
ModuleA moduleA = new ModuleA();
ComponentA componentA = DaggerSubComponent_ComponentA.builder()
.moduleA(moduleA)
.build();
ModuleB moduleB = new ModuleB();
ComponentB componentB = componentA.componentB(moduleB);
}
}