Dagger: 一种Android平台的依赖注入框架
Square是一家专注于移动支付的公司,最近它 推出了一种叫做 Dagger的新库,并将其描述为“一种针对Android和Java的快速依赖注入器”,该库的源码已经发布在 GitHub上。
依赖注入(也叫做 控制反转)已在一些流行的框架中(如 Spring 和 Google Guice)占有重要的位置。然而这些框架仅仅是针对标准JVM而设计的,并不支持诸如Android之类的移动环境。当RoboGuice正尝试提升Guice在Android的体验之时,Dagger通过专注于一种简化的功能集以一种不同的方式达到了更好的性能。
在本文写作时,Dagger已支持以下功能:
- 使用 JSR-330标准注解进行构造器注入
- 使用@Provides注解创建对象
- 针对依赖树的中心上下文
- 昂贵资源延迟注入
- 同一接口的多种实现
- 静态注入 (针对遗留环境)
- 绑定的编译时验证
相对Spring和Guice来说,Dagger针对标准 注入注解只有最基本级别的支持。在Dagger中仅支持构造器的注入,而你无法进行方法注入(向类中进行依赖注入的另一种方式)。Dagger同样提供了@Provides注解,其工作方式类似于Guice。
一旦定义了依赖,你可以通过保存着整棵Dagger初始化对象树的ObjectGraph (对象图谱)来获取那些已被解析的类。它的工作原理类似于Spring的 ApplicationContext 和Guice的 Injector 。Dagger同样也沿用了在Guice中的模块概念(一系列绑定)。
如果以一种迫切的方式创建一些像连接池那样的依赖,会付出相当昂贵的代价。在这种情况下,Dagger支持对这些依赖延迟初始化,而语法也与Guice相似。还有一种情况是对于同一接口会有多种实现并存,Dagger允许你使用@Named注解进行区分。
最后Dagger可以继续使用Factories来取代依赖注入以提供遗留代码的注入。同样的,这种功能的方式与语法与Google Guice相似。
就目前来看,Dagger支持的功能仅是Google Guice的子集。考虑到这两个框架的负责人员存在重叠,所以这是可以理解的。然而,Dagger拥有更小型的配置,并且非常明确是针对Android开发的,而它最明显的不足是缺少对于方法和字段的注入支持。
Dagger牺牲了这项功能却提升了错误检查及探测方面的能力。通常依赖注入错误要等到应用开始运行期间才能得到运行时报告。Dagger却包含了注解的编译时检查,对于不完整的绑定会触发编译错误。这个功能将使得在Android上的应用开发变得更加轻松。
另一项较大的不同之处是,相比于其他流行的框架,Dagger对范围只有的较少的支持。Dagger仅支持@Singleton注解而没有其他范围了。同样这也是可以预料的,因为Android开发的需求有别于标准的Web开发(Web开发伴随着请求和会话的范围)。
值得一提的是Spring用户不仅注意到了Dagger,同时作为Spring相比于Dagger的不足之处,创建了两个关于Spring的问题报告.第一个是 Spring仅能注入本身含有注解的类,而第二个是 Spring无法区分通过泛型实现同一接口的类。
目前Dagger唯一的有效文档是 README,其代码基于Apache2许可开源。注意到该项目尚未有正式的发布版(甚至没有一个源代码的标签),所以当你在评估是否将Dagger用于生产部署时也许需要慎重考虑。
英文原文链接: Dagger: A Dependency Injection Framework For Android
感谢 侯伯薇对本文的审校。
给InfoQ中文站投稿或者参与内容翻译工作,请邮件至 [email protected]。也欢迎大家通过新浪微博( @InfoQ)或者腾讯微博( @InfoQ)关注我们,并与我们的编辑和其他读者朋友交流。