上一节的最后,我讲到一次注入生成类实例的生成步骤。先来回顾一下:

   1  Module中存在创建方法,则看此创建方法有没有参数

      如果有参数,这些参数也是由Component提供的,返回步骤1逐一生成参数类实例,最后再生成最终类实例--ok

      如果无参数,则直接由这个方法生成最终类实例

   2    Module中没有创建方法,则从构造函数里面找那个用@Inject注解的构造函数

      如果该构造函数有参数,则也是返回到步骤1逐一生成参数类实例,最后调用该构造函数生成类实例

      如果该构造函数无参数,则直接调用该构造函数生成类实例

  本节就是验证这些步骤是否可行!!!无参数在上一节中已经介绍过了,所以此处验证都是带参数的

<一>Module中存在创建方法,有参数

    按照上面的步骤,它会先看Component提供的Module有没有提供这个参数,没有的话找这个参数实体类的构造函数生成实例(@inject)。

    1  被依赖类和参数的实体类都是由Module创建

NeedProvide3实例

public class NeedProvide3 {

    public NeedProvide3(Bean3 bean){
} public void printMethod(){
Log.d("Dagger.class","NeedProvide3----printMethod()");
} }

  注意这里的构造器没有用@inject注解修饰,因为这个类的实例要由Module提供。

参数Bean3

public class Bean3 {
public Bean3(){
Log.d("Dagger.class","-------bean3");
}
}

  注意这里的构造器没有用@inject注解修饰,因为这个类的实例要由Module提供。

提供NeedProvide3实例

@Module
public class ProvideModule31 { @Provides
public NeedProvide3 provideNeedProvide(Bean3 bean){
return new NeedProvide3(bean);
} }

提供参数Bean3

@Module
public class ProvideModule32 { @Provides
public Bean3 provideBean(){
return new Bean3();
} }

桥梁Component

@Component(modules={ProvideModule31.class, ProvideModule32.class})
public interface NeedComponent3 {
void inject(TargetActivity3 activity);
Bean3 getBean();//方法名字随意
}

  这里需要提供一个方法,当寻找参数的时候会用到,不写会报错!!!

目标类

public class TargetActivity3 extends AppCompatActivity {

    @Inject
NeedProvide3 mNeedProvide3; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); DaggerNeedComponent3.builder().build().inject(this);
Log.d("Dagger.class","qian----");
mNeedProvide3.printMethod();
Log.d("Dagger.class","--------hou"); }
}

  运行看下打印结果:

  

  2  被依赖类的参数由Module提供,参数由@inject方式创建

这里只有两个类需要改动,这里只贴出这两个类的代码:

参数类:用@inject注解修饰

public class Bean3 {
@Inject
public Bean3(){
Log.d("Dagger.class","-------bean3");
}
}

桥梁Component:删掉了提供Bean3的Module,让Bean3实例由@inject注解创建

@Component(modules={ProvideModule31.class})
public interface NeedComponent3 {
void inject(TargetActivity3 activity);
}

  运行的打印结果和上面的是一样的,说明这两种方法都可以的!!!

<二>Module中不创建方法,有参数

  1  Module中提供参数,被依赖类通过构造器的@inject方式创建

被依赖类:通过@inject方式创建实例

public class NeedProvide4 {
@Inject
public NeedProvide4(Bean4 bean){
} public void printMethod(){
Log.d("Dagger.class","NeedProvide4----printMethod()");
}
}

参数Bean4:无@inject注解

public class Bean4 {
public Bean4(){
Log.d("Dagger.class","-------bean");
}
}

提供参数:

@Module
public class ProvideModule4 { @Provides
public Bean4 provideBean(){
return new Bean4();
} }

桥梁Component

@Component(modules = ProvideModule4.class)
public interface NeedComponent4 {
void inject(TargetActivity4 activity);
}

  运行打印的结果为:

2  被依赖类和参数的实体类都由@inject方式创建

桥梁Component

@Component
public interface NeedComponent4 {
void inject(TargetActivity4 activity);
}

  被依赖类和参数都需要在构造器上使用@inject注解修饰。此处就不贴代码了,运行之后的打印结果和上面的一样。

  本篇主要验证开头所讲的步骤中涉及到的那几种方法是否行的通。最后总结如下:

    1  参数和被依赖类的实例化有两种方法,Module和@inject方式。

    2  当创建依赖类需要参数的时候,参数的实例化有两种方法

        1>Module提供:

          如果依赖类和参数都是Module提供(不由同一个Module提供),那么需要在Component中声明一个方法显示提供,方法名字任意。

        2>@inject方式:

dagger2系列之生成类实例的更多相关文章

  1. Java JUC之Atomic系列12大类实例讲解和原理分解

    Java JUC之Atomic系列12大类实例讲解和原理分解 2013-02-21      0个评论       作者:xieyuooo 收藏    我要投稿 在java6以后我们不但接触到了Loc ...

  2. JUC之Atomic系列12大类实例讲解和原理分解

    在java6以后我们不但接触到了Lock相关的锁,也接触到了很多更加乐观的原子修改操作,也就是在修改时我们只需要保证它的那个瞬间是安全的即可,经过相应的包装后可以再处理对象的并发修改,以及并发中的AB ...

  3. Dagger2系列之使用方法

    本系列只讲使用方法和使用中遇到的问题,如果还对dagger2还不了解的童鞋儿可以参考文章: http://www.jianshu.com/p/cd2c1c9f68d4 http://www.jians ...

  4. XAML实例教程系列 - XAML传递参数到值转换类实例 八

    Kevin Fan分享开发经验,记录开发点滴 XAML实例教程系列 - XAML传递参数到值转换类实例 2012-06-28 05:25 by jv9, 508 阅读, 0 评论, 收藏, 编辑 继上 ...

  5. ASP.NET MVC+EF框架+EasyUI实现权限管理系列(6)- EF上下文实例管理

    原文:ASP.NET MVC+EF框架+EasyUI实现权限管理系列(6)- EF上下文实例管理 ASP.NET MVC+EF框架+EasyUI实现权限管系列 (开篇)   (1):框架搭建    ( ...

  6. 自己动手之使用反射和泛型,动态读取XML创建类实例并赋值

    前言: 最近小匹夫参与的游戏项目到了需要读取数据的阶段了,那么觉得自己业余时间也该实践下数据相关的内容.那么从哪入手呢?因为用的是Unity3d的游戏引擎,思来想去就选择了C#读取XML文件这个小功能 ...

  7. Struts2 源码分析——Result类实例

    本章简言 上一章笔者讲到关于DefaultActionInvocation类执行action的相关知识.我们清楚的知道在执行action类实例之后会相关处理返回的结果.而这章笔者将对处理结果相关的内容 ...

  8. 转:c++类实例在内存中的分配

    转自:http://blog.csdn.net/alexwei2009/article/details/6157926 c++是一种面向对象的编程语言,它向下保持了对c的兼容,同时也允许程序员能够自由 ...

  9. XML之自动生成类,添加,修改,删除类的属性

    1. class ClassHelperDemo { public static void Main() { #region 演示一:动态生成类. //生成一个类t. Type t = ClassHe ...

随机推荐

  1. PHP搭建大文件切割分块上传功能

    背景 在网站开发中,文件上传是很常见的一个功能.相信很多人都会遇到这种情况,想传一个文件上去,然后网页提示"该文件过大".因为一般情况下,我们都需要对上传的文件大小做限制,防止出现 ...

  2. 采用EntityFramework.Extended 对EF进行扩展(Entity Framework 延伸系列2)

    前言 Entity Framework 延伸系列目录 今天我们来讲讲EntityFramework.Extended 首先科普一下这个EntityFramework.Extended是什么,如下: 这 ...

  3. 异步编程 In .NET

    概述 在之前写的一篇关于async和await的前世今生的文章之后,大家似乎在async和await提高网站处理能力方面还有一些疑问,博客园本身也做了不少的尝试.今天我们再来回答一下这个问题,同时我们 ...

  4. Js 变量声明提升和函数声明提升

    Js代码分为两个阶段:编译阶段和执行阶段 Js代码的编译阶段会找到所有的声明,并用合适的作用域将它们关联起来,这是词法作用域的核心内容 包括变量声明(var a)和函数声明(function a(){ ...

  5. 【翻译】MongoDB指南/聚合——聚合管道

    [原文地址]https://docs.mongodb.com/manual/ 聚合 聚合操作处理数据记录并返回计算后的结果.聚合操作将多个文档分组,并能对已分组的数据执行一系列操作而返回单一结果.Mo ...

  6. C#+HtmlAgilityPack+XPath带你采集数据(以采集天气数据为例子)

    第一次接触HtmlAgilityPack是在5年前,一些意外,让我从技术部门临时调到销售部门,负责建立一些流程和寻找潜在客户,最后在阿里巴巴找到了很多客户信息,非常全面,刚开始是手动复制到Excel, ...

  7. redis集成到Springmvc中及使用实例

    redis是现在主流的缓存工具了,因为使用简单.高效且对服务器要求较小,用于大数据量下的缓存 spring也提供了对redis的支持: org.springframework.data.redis.c ...

  8. 算法与数据结构(十三) 冒泡排序、插入排序、希尔排序、选择排序(Swift3.0版)

    本篇博客中的代码实现依然采用Swift3.0来实现.在前几篇博客连续的介绍了关于查找的相关内容, 大约包括线性数据结构的顺序查找.折半查找.插值查找.Fibonacci查找,还包括数结构的二叉排序树以 ...

  9. Python碎碎念

    1. 如何添加路径 主要有以下两种方式: 1> 临时的 import sys sys.path.append('C:\Users\Victor\Desktop') 2> 永久的 在Linu ...

  10. 【开源毕设】一款精美的家校互动APP分享——爱吖校推 [你关注的,我们才推](持续开源更新3)附高效动态压缩Bitmap

    一.写在前面 爱吖校推如同它的名字一样,是一款校园类信息推送交流平台,这么多的家校互动类软件,你选择了我,这是我的幸运.从第一次在博客园上写博客到现在,我一次一次地提高博文的质量和代码的可读性,都是为 ...