【问题标题】:Dagger 2.2 component builder module method deprecated不推荐使用 Dagger 2.2 组件构建器模块方法
【发布时间】:2016-07-30 23:57:28
【问题描述】:

我开始使用 dagger 2.2,组件构建器中的模块方法已被弃用。

这是我的应用程序组件:

@Component(modules = ApplicationModule.class)
public interface ApplicationComponent {
    void inject(Application application);
}

以及应用程序模块:

@Module
public class ApplicationModule {
    Application application;

    public ApplicationModule(Application application) {
        this.application = application;
    }

    @Provides
    @Singleton
    Application providesApplication() {
        return application;
    }
}

这是生成的类:

@Generated(
  value = "dagger.internal.codegen.ComponentProcessor",
  comments = "https://google.github.io/dagger"
)
public final class DaggerApplicationComponent implements ApplicationComponent {
  private DaggerApplicationComponent(Builder builder) {
    assert builder != null;
  }

  public static Builder builder() {
    return new Builder();
  }

  public static ApplicationComponent create() {
    return builder().build();
  }

  @Override
  public void inject(Application application) {
    MembersInjectors.<Application>noOp().injectMembers(application);
  }

  public static final class Builder {
    private Builder() {}

    public ApplicationComponent build() {
      return new DaggerApplicationComponent(this);
    }

    /**
     * @deprecated This module is declared, but an instance is not used in the component. This method is a no-op. For more, see https://google.github.io/dagger/unused-modules.
     */
    @Deprecated
    public Builder applicationModule(ApplicationModule applicationModule) {
      Preconditions.checkNotNull(applicationModule);
      return this;
    }
  }
}

如果不使用 ComponentBuilder,如何初始化组件?

【问题讨论】:

    标签: android dagger-2


    【解决方案1】:

    您应该阅读为什么不推荐使用它的描述。 如果您使用的是 IntelliJ 或 Android Studio 等 IDE,您只需选择方法并点击Control + Q 在 Windows 上阅读 Javadoc,包括弃用通知。

    Javadoc 内容如下:

    @deprecated 此模块已声明,但组件中未使用实例。这种方法是无操作的。更多信息,请参阅https://google.github.io/dagger/unused-modules

    从这个链接你可以看到:

    当 Dagger 处理器生成组件时,它只需要明确需要的模块实例和组件依赖项来提供绑定请求。

    • 如果组件中使用的所有模块方法都是静态的,则 Dagger 根本不需要该模块的实例。 Dagger 无需模块即可直接调用静态方法。
    • 如果模块没有为组件提供绑定,则不需要该模块的实例来构造图。

    可以肯定地说,您可以忽略弃用。它旨在通知您未使用的方法和模块。只要您在子图中的某处实际需要/使用Application,就会需要该模块,并且弃用警告将消失。

    【讨论】:

    • 扫描答案,按 command + Q,Android Studio 关闭。打开大脑,回来,再读一遍答案。
    • Ctrl + J 顺便说一句。 Ctrl + Q 是一种拖钓的尝试。
    • @StarWind 无意拖钓,这 Windows 快捷方式;)
    • @David Medenjak,答案缺失。您只需从源代码复制/粘贴。没有关于如何解决它。
    • @Sever 没错,javadoc 说明了一切。这只是一些关于冗余部分的信息,如最后所述,您可以忽略它。一旦你添加了使用该模块的代码,它就会消失。
    【解决方案2】:

    它显示已弃用,因为您没有在应用程序中使用组件和模块

    @Inject
    SomeObjectFromModule mSomeObject
    

    如果你没有在你的应用程序中注入依赖项,那么初始化你的组件是没有用的,所以 dagger 寻找至少一种用法

    一旦您在要注入视图的任何类中添加这些行,然后清理构建并重新构建项目,您的弃用问题就会得到解决

    【讨论】:

    • 这应该是公认的答案。另外,注入后不要忘记“重建你的项目”。
    【解决方案3】:

    当我的Module 没有@Provides 方法或Dagger 提供的对象未在应用程序中使用时,它会显示错误。
    删除不推荐使用的模块的示例

    模块

    @Module
    public class SecondActivityModule {
        @Provides
        Book provideBookTest() {
            return new Book();
        }
    }
    

    活动

    public class SecondActivity extends AppCompatActivity {
        @Inject
        Book test;
        ...
    }
    

    OR 在组件中

    @Component(modules = SecondModule.class)
    public interface SecondComponent {
    
        void inject(SecondActivity activity);
    
        Book getBookTest();
    }
    

    【讨论】:

      【解决方案4】:

      我对主机有同样的问题,我只是希望每个人都已弃用生成组件构建器类的问题,应该检查两件事以节省时间:

      1/ 更正模块的匕首语法,组件也仔细检查你注入的位置。

      2/ 必须有注入对象(注入注解及其对象),否则匕首编译器无法看到在哪里使用您的模块,因此某些方法将被弃用。只需将至少一个模块提供给您的注入位置并重新编译代码,您将不再有这个问题:)

      【讨论】:

        【解决方案5】:

        如果您在组件类中声明void inject(AppCompactActivity activity);,您将不推荐使用模块方法。而不是您必须使用紧耦合,如 void inject(MainActivity activity); 并重建您的项目,您将看到,模块类中没有弃用方法

        【讨论】:

          猜你喜欢
          • 1970-01-01
          • 1970-01-01
          • 2020-08-07
          • 2012-05-05
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          • 2021-04-18
          相关资源
          最近更新 更多