はい。
Dagger 2 がソース コードを生成するので、何が起こっているのかを簡単に調べることができます。たとえば、次のモジュールを と組み合わせて使用する場合MyClass
:
@Component
@Singleton
public interface MyComponent {
MyClass myClass();
}
次の実装が生成されます。
@Generated("dagger.internal.codegen.ComponentProcessor")
public final class DaggerMyComponent implements MyComponent {
private Provider<MyClass> myClassProvider;
private DaggerMyComponent(Builder builder) {
assert builder != null;
initialize(builder);
}
public static Builder builder() {
return new Builder();
}
public static MyComponent create() {
return builder().build();
}
private void initialize(final Builder builder) {
this.myClassProvider = ScopedProvider.create(MyClass_Factory.create(OtherClass_Factory.create()));
}
@Override
public MyClass myClass() {
return myClassProvider.get();
}
public static final class Builder {
private Builder() {
}
public MyComponent build() {
return new DaggerMyComponent(this);
}
}
}
では、 a がforとして使用されているinitialize(Builder)
ことがわかります。メソッドを呼び出すと、シングルトンとして実装されているのメソッドが呼び出されます。ScopedProvider
Provider
MyClass
myClass()
ScopedProvider
get()
public T get() {
// double-check idiom from EJ2: Item 71
Object result = instance;
if (result == UNINITIALIZED) {
synchronized (this) {
result = instance;
if (result == UNINITIALIZED) {
instance = result = factory.get();
}
}
}
return (T) result;
}