Dagger2源码剖析
Dagger是一个非常优秀的IOC框架,使用Dagger能够极大减少代码耦合,介绍Dagger如何使用的文章网上有很多,在这里给大家推荐3篇,作者讲得非常白话,大家应该可以理解:
在使用过Dagger之后,大家不免会对其实现原理产生疑问,本文就对Dagger的源码进行剖析。(由于dagger代码并未开源,一些细节方面的东西可能讲不到)
首先Dagger是基于APT开发的,所以请大家先看下我之前写的一篇文章
好的,终于完成了系列的准备工作,
接下来咱们还是沿着我上篇文章中提到的编译期注解的三要素,一一剖析Dagger框架
注解
dagger里面常用的注解
无非就是
- @Inject
- @Moudel
- @Component
- @Qualifier
- @Scope
@Target({ METHOD, CONSTRUCTOR, FIELD })
@Retention(RUNTIME)
@Documented
public @interface Inject {
}
@Target(ANNOTATION_TYPE)
@Retention(RUNTIME)
@Documented
public @interface Qualifier {
}
@Target(ANNOTATION_TYPE)
@Retention(RUNTIME)
@Documented
public @interface Scope {
}
这3个注解不来自dagger,而来自java本身!,通过这些注解的源码我们关键要捕获一个信息,这些注解在哪里使用,可以看到Inject可以在方法,构造方法,属性上面使用,而Qualifier和Scope则只能在注解上面使用(意味着我们不能直接使用他们,所以就有了@Name @Singleton这些注解)
再看看dagger自己写的注解
@Retention(RUNTIME)
@Target(TYPE)
@Documented
public @interface Component {
Class<?>[] modules() default {};
Class<?>[] dependencies() default {};
}
Component注解在类上,可以包含多个Modules,也可以依赖多个Component.
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.TYPE)
public @interface Module {
Class<?>[] includes() default {};
}
Module也是注解在类上
@Documented
@