Dagger 2从浅到深(二)

Dagger系列:

  1. Dagger 2从浅到深(一)
  2. Dagger 2从浅到深(二)
  3. Dagger 2从浅到深(三)
  4. Dagger 2从浅到深(四)
  5. Dagger 2从浅到深(五)
  6. Dagger 2从浅到深(六)
  7. Dagger 2从浅到深(七)
  8. Dagger 2应用于Android的完美扩展库-dagger.android


Demo地址:

  1. DaggerLearn
  2. Kotlin-Dagger-2-Retrofit-Android-Architecture-Components



Dagger 2从浅到深(一)中,了解到Dagger依赖注入的基本用法,心里有两个盲点:

  1. @Provides是什么呢?
  2. 注解的构造函数是有参构造函数,该如何传递参数?

带着这两个疑问,开始本文章的话题。

所涉及到的注解

@Provides

@Provides可以认为是对@Inject的补充。对于@Inject不能满足的情况,可以使用@Provides注解方法来满足依赖性,该方法的定义返回类型满足了其依赖关系。不管是接口还是第三方库的类,甚至是相关的配置对象,都可以通过@Provides方法来提供了,以弥补@Inject的盲区。

例如:每当需要StudentBean实例时,都会调用provideStudent方法:

@Provides 
static StudentBean provideStudent() {
  return new StudentBean();
}

甚至,@Provides方法本身可能也拥有自身的依赖关系。例如,每当需要StudentBean实例时,都会需要依赖注入AreaBean实例。

@Provides 
static StudentBean provideStudent(AreaBean area) {
  return new StudentBean(area);
}

按照惯例,对于@Provides方法的命名以provide为前缀,例如, provideXx.

值得注意的是,@Provides方法本身是不能独立存在的,它必须依附于一个Module。所谓的Module是具有@Module注解的类。关于@Moduel是什么?后续即将讲解。

@Module

@Module源码:

public @interface Module {
  /**
   * 本身依赖的其他的Module
   */
  Class<?>[] includes() default {};

  /**
   * 注入该模块的子组件
   * 一个子组件中,可以注入多个Module
   */
  @Beta
  Class<?>[] subcomponents() default {};
}
</
  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值