Java框架!Dagger2源码分析(三
Posted 普通网友
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java框架!Dagger2源码分析(三相关的知识,希望对你有一定的参考价值。
@Override
public String toString()
return "Engine" +
"name='" + name + '\\'' +
'';
public void run()
System.out.println("引擎转起来了~~~");
接着我们需要一个Module类来生成依赖对象。前面介绍的@Module就是用来标准这个类的,而@Provide则是用来标注具体提供依赖对象的方法(这里有个不成文的规定,被@Provide标注的方法命名我们一般以provide开头,这并不是强制的但有益于提升代码的可读性)。
```java
@Module
public class MarkCarModule
public MarkCarModule()
/**
* 用于标注Module所标注的类中的方法,该方法在需要提供依赖时被调用,从而把预先提供好的对象当做依赖给标注了@Inject的变量赋值
* @return
*/
@Provides
Engine provideEngine()
return new Engine("gear");
接下来我们还需要对CarComponent进行一点点修改,之前的@Component注解是不带参数的,现在我们需要加上modules = MarkCarModule.class,用来告诉Dagger2提供依赖的是MarkCarModule这个类。
@Component(modules = MarkCarModule.class)
public interface CarComponent
void inject(Car car);
Car类的构造函数我们也需要修改,相比之前多了个markCarModule(new MarkCarModule())方法,这就相当于告诉了注入器DaggerCarComponent把MarkCarModule提供的依赖注入到了Car类中。
public class Car
/**
* 我们提到@Inject和@Module都可以提供依赖,那如果我们即在构造函数上通过标记@Inject提供依赖,有通过@Module提供依赖Dagger2会如何选择呢?具体规则如下:
*
* 步骤1:首先查找@Module标注的类中是否存在提供依赖的方法。
* 步骤2:若存在提供依赖的方法,查看该方法是否存在参数。
* a:若存在参数,则按从步骤1开始依次初始化每个参数;
* b:若不存在,则直接初始化该类实例,完成一次依赖注入。
*
*
* 步骤3:若不存在提供依赖的方法,则查找@Inject标注的构造函数,看构造函数是否存在参数。
* a:若存在参数,则从步骤1开始依次初始化每一个参数
* b:若不存在,则直接初始化该类实例,完成一次依赖注入
*/
@Inject
Engine engine;
public Car()
DaggerCarComponent.builder().markCarModule(new MarkCarModule())
.build().inject(this);
public Engine getEngine()
return this.engine;
public static void main(String ... args)
//TODO:
Car car = new Car();
System.out.println(car.getEngine());
这样一个最最基本的依赖注入就完成了,接下来我们测试下我们的代码。
输出
Enginename='gear'
3、案例C
那么如果一台汽车有两个引擎(也就是说Car类中有两个Engine变量)怎么办呢?没关系,我们还有@Qulifier!首先我们需要使用Qulifier定义两个注解:
public class Engine
/**
* 用于自定义注解,也就是说@Qulifier就如同Java提供的几种基本元注解一样用来标记注解类。我们在使用@Module来标注提供依赖的方法时,方法名我们是可以随便定义的(虽然我们定义方法名一般以provide开头,但这并不是强制的,只是为了增加可读性而已)。那么Dagger2怎么知道这个方法是为谁提供依赖呢?答案就是返回值的类型,Dagger2根据返回值的类型来决定为哪个被@Inject标记了的变量赋值。但是问题来了,一旦有多个一样的返回类型Dagger2就懵逼了。@Qulifier的存在正式为了解决这个问题,我们使用@Qulifier来定义自己的注解,然后通过自定义的注解去标注提供依赖的方法和依赖需求方(也就是被@Inject标注的变量),这样Dagger2就知道为谁提供依赖了。----一个更为精简的定义:当类型不足以鉴别一个依赖的时候,我们就可以使用这个注解标示
* 1. 使用@Qulifier定义两个注解
*/
@Qualifier
@Retention(RetentionPolicy.RUNTIME)
public @interface QualifierA
@Qualifier
@Retention(RetentionPolicy.RUNTIME)
public @interface QualifierB
private String name;
Engine(String name)
this.name = name;
@Override
public String toString()
return "Engine" +
"name='" + name + '\\'' +
'';
public void run()
System.out.println("引擎转起来了~~~");
同时我们需要对依赖提供方做出修改
@Module
public class MarkCarModule
public MarkCarModule()
/**
* 2. 同时我们需要对依赖提供方做出修改
* @return
*/
@Engine.QualifierA
@Provides
Engine provideEngineA()
return new Engine("gearA");
@Engine.QualifierB
@Provides
Engine provideEngineB()
return new Engine("gearB");
接下来依赖需求方Car类同样需要修改
public class Car
/**
* 3. 接下来依赖需求方Car类同样需要修改
*/
@Engine.QualifierA
@Inject
Engine engineA;
@Engine.QualifierB
@Inject
Engine engineB;
public Car()
DaggerCarComponent.builder().markCarModule(new MarkCarModule())
.build().inject(this);
public Engine getEngineA()
return this.engineA;
public Engine getEngineB()
return this.engineB;
public static void main(String... args)
//TODO:
Car car = new Car();
System.out.println(car.getEngineA());
System.out.println(car.getEngineB());
执行结果:
Enginename='gearA'
Enginename='gearB'
4、案例D
接下来我们看看@Scope是如何限定作用域,实现局部单例的。
首先我们需要通过@Scope定义一个CarScope注解:
public class Engine
/**
* 用于自定义注解,我能可以通过@Scope自定义的注解来限定注解作用域,实现局部的单例
* 1. @Scope定义一个CarScope注解
*/
@Scope
@Retention(RetentionPolicy.RUNTIME)
public @interface CarScope
private String name;
Engine(String name)
this.name = name;
System.out.println("Engine create: " + name);
@Override
public String toString()
return "Engine" +
"name='" + name + '\\'' +
'';
public void run()
System.out.println("引擎转起来了~~~");
接着我们需要用这个@CarScope去标记依赖提供方MarkCarModule。
@Module
public class MarkCarModule
public MarkCarModule()
/**
* 2. @CarScope去标记依赖提供方MarkCarModule
* @return
*/
@Engine.CarScope
@Provides
Engine provideEngine()
return new Engine("gear");
同时还需要使用@Scope去标注注入器Compoent
最后
小编在这里分享些我自己平时的学习资料,由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!有需要的程序猿(媛)可以关注+点赞,点击这里免费获取
程序员代码面试指南 IT名企算法与数据结构题目最优解
这是” 本程序员面试宝典!书中对IT名企代码面试各类题目的最优解进行了总结,并提供了相关代码实现。针对当前程序员面试缺乏权威题目汇总这一-痛点, 本书选取将近200道真实出现过的经典代码面试题,帮助广“大程序员的面试准备做到万无一失。 “刷”完本书后,你就是“题王”!
《TCP-IP协议组(第4版)》
本书是介绍TCP/IP协议族的经典图书的最新版本。本书自第1版出版以来,就广受读者欢迎。
本书最新版进行」护元,以体境计算机网络技不的最新发展,全书古有七大部分共30草和7个附录:第一部分介绍一些基本概念和基础底层技术:第二部分介绍网络层协议:第三部分介绍运输层协议;第四部分介绍应用层协议:第五部分介绍下一代协议,即IPv6协议:第六部分介绍网络安全问题:第七部分给出了7个附录。
Java开发手册(嵩山版)
这个不用多说了,阿里的开发手册,每次更新我都会看,这是8月初最新更新的**(嵩山版)**
MySQL 8从入门到精通
本书主要内容包括mysql的安装与配置、数据库的创建、数据表的创建、数据类型和运算符、MySQL 函数、查询数据、数据表的操作(插入、更新与删除数据)、索引、存储过程和函数、视图、触发器、用户管理、数据备份与还原、MySQL 日志、性能优化、MySQL Repl ication、MySQL Workbench、 MySQL Utilities、 MySQL Proxy、php操作MySQL数据库和PDO数据库抽象类库等。最后通过3个综合案例的数据库设计,进步讲述 MySQL在实际工作中的应用。
Spring5高级编程(第5版)
本书涵盖Spring 5的所有内容,如果想要充分利用这一领先的企业级 Java应用程序开发框架的强大功能,本书是最全面的Spring参考和实用指南。
本书第5版涵盖核心的Spring及其与其他领先的Java技术(比如Hibemate JPA 2.Tls、Thymeleaf和WebSocket)的集成。本书的重点是介绍如何使用Java配置类、lambda 表达式、Spring Boot以及反应式编程。同时,将与企业级应用程序开发人员分享一些见解和实际经验,包括远程处理、事务、Web 和表示层,等等。
JAVA核心知识点+1000道 互联网Java工程师面试题
企业IT架构转型之道 阿里巴巴中台战略思想与架构实战
本书讲述了阿里巴巴的技术发展史,同时也是-部互联网技 术架构的实践与发展史。
人员分享一些见解和实际经验,包括远程处理、事务、Web 和表示层,等等。
[外链图片转存中…(img-ZNzgptmr-1628072376534)]
JAVA核心知识点+1000道 互联网Java工程师面试题
[外链图片转存中…(img-kxBX3JXN-1628072376535)]
[外链图片转存中…(img-L7QFF1B6-1628072376536)]
企业IT架构转型之道 阿里巴巴中台战略思想与架构实战
本书讲述了阿里巴巴的技术发展史,同时也是-部互联网技 术架构的实践与发展史。
以上是关于Java框架!Dagger2源码分析(三的主要内容,如果未能解决你的问题,请参考以下文章