从实例出发理解Dagger2(五)

上一片文章最后提到的容易让人误解的@Singleton希望大家要记住。 等等,说起来好像上上上篇文章里还有一个抬杠还没解决啊。就是如果在Module里两个Provider返回的类型是相同的,Dagger怎么知道使用哪个Provider提供的依赖注入呢?而且如果你真的在Module的两个Provdier中返回相同的类型,在编译时是会报错的!因为Dagger也不知道使用哪个,只好报错:你TM想要我用哪个?说清楚!
这时就会引出另外两个注解啦---Qualifier和Named!

举个常见的例子,就是通过Dagger提供Context。除了Application可以提供Context外,Activity也可以提供Context。代码如下:

image.png

还记得@Module@Provides@GithubApplicationScope是什么意思吗?不记得可以回去翻翻上面的文章哦。
问题来了,如果把ActivityModule和ContextModule放到一起,Dagger在编译的时候就会因为不知道要用哪个Context报错。那么怎么解决这个问题呢?有两种方法:

  1. @Named 直接贴代码:
    image.png

    @Named 后面的activity_context就是在告诉Dagger,这是一个叫activity_context的Context。
    在要使用的context前面加上相同的注解即可,这样Dagger就知道具体使用的是哪个Context了。编译时就能 正常通过了。
    image.png

大家发现没有,这样把字符串加来加去不仅麻烦还容易出错。那有没有其他方法呢?来,看下面一条。

  1. @Qualifier
    在看@Qualifier 之前让我们先看看@Named 的源码:
    image.png

    咦?这个@Named 不就是一个 @Qualifier 嘛!那自己自定义一个专用@Qualifier 得了。代码如下:
    image.png

这样就不需要把字符串拷来拷去了,而且方便阅读和理解代码。具体的用法见下面代码:


image.png

image.png

好了,抬杠圆满结束。让我们开始下面的内容!

相关文章:
从实例出发理解Dagger2(一)
从实例出发理解Dagger2(二)
从实例出发理解Dagger2(三)
从实例出发理解Dagger2(四)
从实例出发理解Dagger2(五)
从实例出发理解Dagger2(六)
从实例出发理解Dagger2(七)

参考资料:https://www.youtube.com/watch?v=WAENNp2wxbQ&index=5&list=PLuR1PJnGR-Ih-HXnGSpnqjdhdvqcwhfFU

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,114评论 25 709
  • 本文的分析基于dagger2的2.7版本。 谷歌开发维护的Dagger2出来有很长时间了,目前在很多开源项目上也能...
    sososeen09阅读 13,665评论 31 108
  • 部分内容参考自:[Android]使用Dagger 2依赖注入 - DI介绍(翻译)[Android]使用Dagg...
    AItsuki阅读 47,859评论 66 356
  • 今天早起,醒了,却不想起床,藏在被窝里和群里的朋友们闲聊。聊到彩色皮的饺子,聊到食材的营养健康,聊到美食的艺术魅力...
    诗桦阅读 2,886评论 6 12
  • 前一段时间还在看姐姐的文章,由于忘记了女儿的生日,那种内疚与自责与担心与懊悔…… 可怜的我,直到今天才发现,我的大...
    梦小嘟阅读 278评论 0 3