本篇是实战文章,从代码的角度分析这两种方式。本文参考自下列文章:

      http://www.jianshu.com/p/1d42d2e6f4a5

      http://www.jianshu.com/p/94d47da32656

  一般在项目中我们需要全局使用app或者其他,这个时候就需要有一个全局的Component作为桥梁,提供给使用方使用。一个Component可以依赖一个或多个Component,并拿到被依赖Component 暴露 出来的实例。

<一>依赖关系

全局提供App实例类、上下文Context

  1. @Module
  2. public class AppModule5 {
  3.  
  4. private App5 app;
  5.  
  6. public AppModule5(App5 app) {
  7. this.app = app;
  8. }
  9.  
  10. @Provides
  11. public App5 provideApp() {
  12. return app;
  13. }
  14.  
  15. @Provides
  16. Context provideApplicationContext() {
  17. return app.getApplicationContext();
  18. }
  19. }

提供 全局提供App实例类、上下文Context桥梁,该Component会被其他Component依赖

  1. @Component(modules = {AppModule5.class})
  2. public interface AppComponent5 {
  3. void inject(App5 app);
  4.  
  5. //因为AppComponent会被dependencies,所以此处Module中提供的内容,我们需要在此处声明一下
  6. App5 getApp();
  7. Context getApplicationContext();
  8. }

  由于AppComponent5会被其他Component依赖,所以此处需要显示地声明AppModule5中提供的东西,此处的方法名任意!!!

App被全局提供

  1. public class App5 extends Application {
  2.  
  3. private AppComponent5 mAppComponent5;
  4.  
  5. @Override
  6. public void onCreate() {
  7. super.onCreate();
  8. mAppComponent5 = DaggerAppComponent5.builder().appModule5(new AppModule5(this)).build();
  9. mAppComponent5.inject(this);
  10. }
  11.  
  12. public AppComponent5 getAppComponent5(){
  13. return mAppComponent5;
  14. }
  15.  
  16. }

  若Module的构造器需要参数,我们就需要在这里appModule5(new AppModule5()),若Module的构造器中不需要参数,此处可以省略!!!需要通过这种方式将参数传递进去。

提供被依赖类:

  1. @Module
  2. public class ActivityModule5 {
  3.  
  4. @Provides
  5. public DependencyPresenter getDependencyPresenter(App5 app){
  6. return new DependencyPresenter(app);
  7. }
  8. }

桥梁:

  1. @Component(dependencies = AppComponent5.class,modules = ActivityModule5.class)
  2. public interface ActivityComponent {
  3. void inject(TargetActivity5 activity5);
  4. }

  使用了Component的dependencies属性,ActivityModule5提供被依赖类,AppComponent5提供被依赖类的参数(全局提供)。

被依赖类:此处没用@inject修饰构造器

  1. public class DependencyPresenter {
  2.  
  3. public DependencyPresenter(App5 app){
  4. Log.d("Dagger.class","DependencyPresenter-----构造器------(app == null)?????:"+(app == null));
  5. }
  6.  
  7. public void printMethod(){
  8. Log.d("Dagger.class","DependencyPresenter-----printMethod()-----");
  9. }
  10.  
  11. }

目标类

  1. public class TargetActivity5 extends AppCompatActivity {
  2.  
  3. @Inject
  4. DependencyPresenter mDependencyPresenter;
  5.  
  6. @Override
  7. protected void onCreate(Bundle savedInstanceState) {
  8. super.onCreate(savedInstanceState);
  9. setContentView(R.layout.activity_main);
  10.  
  11. App5 app5 = (App5) this.getApplication();
  12.  
  13. DaggerActivityComponent.builder().appComponent5(app5.getAppComponent5()).build().inject(this);
  14.  
  15. mDependencyPresenter.printMethod();
  16. }
  17. }

  由于ActivityComponent依赖AppComponent,所以需要在此处添加声明appComponent(app5.getAppComponent)。

  由此得到结论:需要在Component中显示的声明提供 被依赖类 的方法(方法名任意)

    1 同一个Component的两个Module之间,当ModuleA需要ModuleB提供参数,在Component中需要提供获取参数的方法

    2 ComponentA和它所依赖的ComponentB之间,若ComponentA需要ComponentB提供参数,在ComponentB中需要显示声明方法

<二>包含方式(从属方式)@SubComponent

  当我们的Component需要依赖全局的Component提供的实例或者参数的时候,我们上面的实现方式是选择Component的dependencies属性,此时需要在被依赖的Component中有显示的声明。这里介绍另一种方法,包含方式。相比于依赖方式,包含方式不需要在父Component中显示的提供方法,就可以拿到想要的东西。下面看一下代码:

使用@Subcomponent注解标注ActivityModule6,代表它是子Component

  1. @Subcomponent(modules = ActivityModule6.class)
  2. public interface ActivityComponent6 {
  3. void inject(TargetActivity6 activity5);
  4. }

父Component:

  1. @Component(modules = {AppModule6.class})
  2. public interface AppComponent6 {
  3. void inject(App6 app);
  4.  
  5. ActivityComponent6 getSubComponent();
  6. }

  需要在父Component中声明自己的子Component,方法名任意。如果ActivityComponent6中的Module的构造器需要参数,则在此处传递进去,譬如:

  1. ActivityComponent6 getSubComponent(new ActivityModule6("参数"));

目标类:使用方式上也有区别

  1. public class TargetActivity6 extends AppCompatActivity {
  2.  
  3. @Inject
  4. DependencyPresenter6 mDependencyPresenter;
  5.  
  6. @Override
  7. protected void onCreate(Bundle savedInstanceState) {
  8. super.onCreate(savedInstanceState);
  9. setContentView(R.layout.activity_main);
  10.  
  11. App6 app6 = (App6) this.getApplication();
  12. app6.getAppComponent6().getSubComponent().inject(this);
  13. mDependencyPresenter.printMethod();
  14. }
  15. }

  其他类均没有变化。依赖方式、包含方式介绍到此为止~更多的内容请参看上面的链接!!!

dagger2系列之依赖方式dependencies、包含方式(从属方式)SubComponent的更多相关文章

  1. Spring系列之依赖注入的方式

    一.依赖注入方式 对于spring配置一个bean时,如果需要给该bean提供一些初始化参数,则需要通过依赖注入方式,所谓的依赖注入就是通过spring将bean所需要的一些参数传递到bean实例对象 ...

  2. Spring系列之aAOP AOP是什么?+xml方式实现aop+注解方式实现aop

    Spring系列之aop aop是什么?+xml方式实现aop+注解方式实现aop 什么是AOP? AOP为Aspect Oriented Programming 的缩写,意识为面向切面的编程,是通过 ...

  3. 【Xamarin 挖墙脚系列:IOS 开发界面的3种方式】

    原文:[Xamarin 挖墙脚系列:IOS 开发界面的3种方式] xcode6进行三种基本的界面布局的方法,分别是手写UI,xib和storyboard.手写UI是最早进行UI界面布局的方法,优点是灵 ...

  4. 依赖注入之unity(winform方式)

    依赖注入之unity(winform方式) 要讲unity就必须先了解DI和IOC及DIP,如下链接提供DI和IOC的基础:https://www.cnblogs.com/zlp520/p/12015 ...

  5. 万恶技术系列笔记-jupyter工作路径和源文件打开方式

    万恶技术系列笔记-jupyter工作路径和源文件打开方式   脚本文件,ipynb的正确打开姿势: ipynb不能直接打开,需要复制到工作路径.例如 10_monkeys_model_1.ipynb ...

  6. Java Array数组 遍历 四种方式(包含 Lambda 表达式遍历)

    示例代码如下: package com.miracle.luna.lambda; import java.util.Arrays; /** * @Author Miracle Luna * @Date ...

  7. Java List集合 遍历 四种方式(包含 Lambda 表达式遍历)

    示例代码如下: package com.miracle.luna.lambda; import java.util.ArrayList; import java.util.List; /** * @A ...

  8. Java Map集合 遍历 五种方式(包含 Lambda 表达式遍历)

    示例代码如下: package com.miracle.luna.lambda; import java.util.HashMap; import java.util.Iterator; import ...

  9. Gradle学习系列之七——依赖管理

    在本系列的上篇文章中,我们讲到了如何使用java Plugin,在本篇文章中,我们将讲到Gradle的依赖管理. 请通过以下方式下载本系列文章的Github示例代码: git clone https: ...

随机推荐

  1. 一起来玩echarts系列(一)------箱线图的分析与绘制

    一.箱线图 Box-plot 箱线图一般被用作显示数据分散情况.具体是计算一组数据的中位数.25%分位数.75%分位数.上边界.下边界,来将数据从大到小排列,直观展示数据整体的分布情况. 大部分正常数 ...

  2. 分布式锁1 Java常用技术方案

    前言:       由于在平时的工作中,线上服务器是分布式多台部署的,经常会面临解决分布式场景下数据一致性的问题,那么就要利用分布式锁来解决这些问题.所以自己结合实际工作中的一些经验和网上看到的一些资 ...

  3. JavaScript 字符串实用常操纪要

    JavaScript 字符串用于存储和处理文本.因此在编写 JS 代码之时她总如影随形,在你处理用户的输入数据的时候,在读取或设置 DOM 对象的属性时,在操作 Cookie 时,在转换各种不同 Da ...

  4. 在Asp.Net中操作PDF – iTextSharp - 使用表格

    使用Asp.Net生成PDF最常用的元素应该是表格,表格可以帮助比如订单或者发票类型的文档更加格式化和美观.本篇文章并不会深入探讨表格,仅仅是提供一个使用iTextSharp生成表格的方法介绍 使用i ...

  5. SDWebImage源码解读 之 UIImage+GIF

    第二篇 前言 本篇是和GIF相关的一个UIImage的分类.主要提供了三个方法: + (UIImage *)sd_animatedGIFNamed:(NSString *)name ----- 根据名 ...

  6. Spark踩坑记——初试

    [TOC] Spark简介 整体认识 Apache Spark是一个围绕速度.易用性和复杂分析构建的大数据处理框架.最初在2009年由加州大学伯克利分校的AMPLab开发,并于2010年成为Apach ...

  7. 【深入Java虚拟机】之四:类加载机制

    类加载过程     类从被加载到虚拟机内存中开始,到卸载出内存为止,它的整个生命周期包括:加载.验证.准备.解析.初始化.使用和卸载七个阶段.它们开始的顺序如下图所示: 其中类加载的过程包括了加载.验 ...

  8. php cryptr 加密函数

    class CryptHelper { /** * 加密 * @param unknown $password * @param unknown $salt * @return string */ p ...

  9. Android之Pull解析XML

    一.Pull解析方法介绍 除了可以使用SAX和DOM解析XML文件,也可以使用Android内置的Pull解析器解析XML文件.Pull解析器的运行方式与SAX解析器相似.它也是事件触发的.Pull解 ...

  10. 不要着急改代码,先想想--centos 6.8下编译安装tmux

    诸位读者新年好,2017开年第一篇博客,请允许我先问候一下看到这篇博客的诸位.写博客是我2017年定下的目标之一,希望我会坚持下去. 最近打算尝试一下tmux这个神器,于是有了这一篇关于思维方式的Bl ...