Dagger 2.0 构造函数注入和单例

Dagger 2.0 Constructor injection and Singleton

是否可以同时使用 Dagger 2.0 构造函数注入和单例。 我在文档中找不到答案。

示例:

@Singleton
public class MyClass {
   private final OtherClass member;

   @Inject
   public MyClass(OtherClass member){
        this.member = member;
   }
 }

构造函数注入确实有效。但是,如果我在 class?

上写 @Singleton,是否可以保证 MyClass 被创建为单例?

谢谢

是的。

由于 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);
    }
  }
}

initialize(Builder)中,你可以看到ScopedProvider被用作MyClassProvider。在调用myClass()方法时,调用了ScopedProviderget()方法,作为单例实现:

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;
}