Android-Dagger2使用--1(原创)
不知不觉又是一年,这一年,Android技术与架构依旧不断推陈出新,各种开源框架层出不穷,非常感谢大Android市场为我们带来的机遇与挑战,可能是这一年Android市场的风起云涌和以及各种新技术的冲击,不得不要求自己去做一点什么.思来想去还是闲暇之余写写文章,可能是在项目中使用到的技术,亦或是优秀的第三方开源框架的使用,亦或是一些读书笔记,亦或是随笔散文,在Android8.0来临之际,希望自己可以坚持下来,加油。
网上关于Dagger2的讲解使用其实非常详细了,这里就简单的介绍下Dagger的基本使用。Dagger,英译中:匕首、短剑的意思,这是一款非常优秀的“依赖注入”框架,(拓展:IOC,英文全称:Inversion of Control,中文名称:控制反转,它还有个名字叫依赖注入(Dependency Injection)。作用:将各层的对象以松耦合的方式组织在一起,解耦,各层对象的调用完全面向接口。)关于具体的原理和逻辑,仁者见仁智者见智。我理解的就是通过这个框架以接口这种形式去完成原来的new Object(),完成最终的解耦。
举个例子,我们现在需要一个类叫Dog,Dog这个类中中需要持有一个叫Eat的对象,Eat中又需要持有Food对象,Ok,这还不简单,胸有成竹潇潇洒洒就是如下代码:
Dog dog = new Dog (new Eat (new Food()) );
但是在实际开发中,我们遇到的情况却是这样子的,
哦,上帝,我好像原来也是这样写的,这样一坨一坨的,看上去很相似吧,自己看自己写的还好,要是遇见别人写的(不写注释不写备注写的个个像混淆后似的)那就灰常老火了,这个时候,Dagger就像极了一个好人双眼放光似地说道,new Object()那家强,免费干活不嫌累那家强?It's me! 简而言之,Dagger只用专注于怎么实现功能,至于对象的依赖关系和生命周期,都让它来帮我们管理。
接下来,还有一幅图,
那么,Dagger2的铁三角就来了:
1)Module 提供依赖,(类似经济学里面的供给方)
2)Component关联依赖,类似于一个容器,中间商(供给方---需求方,两者联系的桥梁),连接器
3)Container 使用依赖,(类似于经济学里面的需求方)
重要的注解:
1)@Inject ,在需要依赖(也就是需要具体的对象)时候使用这个注解,
2)@Module ,这个里面的方法专门提供依赖,用此注解的时候,Dagger在构造类的实例的时候就知道去那里找到需要的依赖,
3)@Provide ,这个注解,主要是用来提供依赖,(与@inject互相对应,供给方or需求方一 一对应的关系)
4)@Component ,连接的桥梁,也称为注入器,Dagger源代码里面,此注解需要Module,本质是一个interface,这个接口本身不提供实例对象,由注解@Component 后面的{}里面的.class去提供,
下面就开始正式使用Dagger2:
1)在 Module:app builde.gradle
apply plugin: 'com.android.application'的下面,新增:
apply plugin: 'com.neenbedankt.android-apt'
(凡是这种通过构建自动生成代码的,基本上都要安装插件)
2)在 Module:app builde.gradle
dependencies {
新增如下3行:
compile 'com.google.dagger:dagger:2.0.2' //依赖
compile 'com.google.dagger:dagger-compiler:2.0.2' //指定注解处理器
provided 'org.glassfish:javax.annotation:10.0-b28' //添加Android缺失部分的javax注解
}
3)在 Project:XXX builde.gradle
dependencies{
//新增下面一行
classpath'com.neenbedankt.gradle.plugins:android-apt:1.8'
}
基本的Dagger配置就是上述步骤,然后同步一下开发工具.
第一篇的使用,我们来了解最基本的用法,我们就定义一个JavaBean,里面有个方法,用来打印日志
First ,我们就有了如下代码:
Second ,我们在Activity里面使用这个JavaBean,调用里面的方法,传统工艺告诉我们需要new 对象,然后调用其方法,
但是!!! 在Dagger里想使用一个具体的对象,如图Dagger-1,使用@Inject 注解 告诉Dagger 我想要使用这个对象(依赖)
潇潇洒洒就有了以下的代码,
接下来,依旧如图Dagger-1,现在有了@Inject,(笔者是文科出身,这里引申一个经济学的理论,有了需求(@inject),也有了供给(@provide),但如何保证需求与供给平衡?大萧条的惨痛经验告诉我们仅依靠市场规律是不行滴,两者还需要政府的宏观调控(也就是@Component)来把控全局),于是乎,我们定义一个@Component
关于这个inject()方法,方法参数为ManActivity,
我们先简单的理解,就是声明MainActivity这个类,用来指定这个@Component和@Module
接着,我们点进去看,注解的源码需要我们提供一个modules的依赖
需要注意的是,这个@Component本身不提供依赖,提供依赖的步骤是在{}花括号里面的.class文件去处理实例对象
Thirdly : 接下来,我们就需要完成具体的@Moudle
我们将,HttpModule这个类,以@Module注解标注,
告知Dagger2,我这个类是为了给使用到@Component,里面使用了(modules= {HttpMoudle.class})结合使用的
@Provide 这个注解在上文说的也很清楚了,这个与@Inject是直接对应的,类似与之前提到的供给or需求的关系
图上注解@Provide的这个方法,返回一个FirstUseDagger对象(恍然大悟, 我们之前的new 对象的方式 就在这里被替换完成了)
整体的代码思路就是,
A-->声明Module;
B-->在@Provides注解里面,返回对象;对外提供依赖
C-->整个Module的职责是给@Component提供一个对象供给仓库
D-->在Container里面,使用Dagger2为我们提供的依赖
Fourthly:
代码写到这里,我们点击同步(Sync now),或者编译代码,这个时候,Dagger的插件会为我们生成一些代码,
我这里的@Component 使用的是HttpComponent,系统为我生成的是DaggerHttpComponent,由于我这里是第一篇,最基础的,
那么,在我们的MainActivity,里面,直接
A-->用@Inject注解,告知Dagger2,我要使用(需求方)这个对象,
B-->我们思考传统的写法,如果没有这个对象,如果对象名调用方法名()就直接抛空指针异常,
C-->在上文说到,Dagger2的对象提供由@Provide提供(供给方)去满足new 对象
D-->两者的桥梁由@Components链接对应
E-->简单的使用:DaggerXXXComponent.create().inject(this);
附上编译后生成的源代码:
由于是Dagger2的第一篇,所以也只是非常简单的讲解下概念,入门使用,后续文章会逐渐扩展,
也希望大家多多支持.

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
《Cisco IOS XR技术精要》一2.1 Cisco IOS XR内核
本节书摘来自异步社区《Cisco IOS XR技术精要》一书中的第2章,第2.1节,作者 【美】Mobeen Tahir , Mark Ghattas , Dawit Birhanu , Syed Natif Nawaz,更多章节内容可以访问云栖社区“异步社区”公众号查看 2.1 Cisco IOS XR内核 Cisco IOS XR技术精要Cisco IOS XR是一款基于微内核、高度分布的操作系统。Cisco IOS XR中使用的微内核是一种由QNX Software Systems公司开发的QNX Neutrino实时操作系统(RTOS),其使用的内核是轻量级的,仅提供了少量必要的服务。该系统负责终端处理、调度、任务交换、内存管理、同步、进程间通信等工作。微内核系统不包括如设备驱动器、文件系统和网络栈之类的系统服务;这些服务是通过内核外的独立进程来执行的,可以像其他应用那样重新启动。 微内核是一种兼容POSIX(可移植操作系统接口)的内核。POSIX定义了兼容POSIX的OS必须遵循的OS规范和针对API和OS服务的测试组。基于POSIX兼容的内核开发的应用和服务可以方便地移植到...
- 下一篇
“Xavier”安卓木马分析:可静默收集数据并远程代码执行
趋势科技研究发现了一款Android恶意木马——Xavier。在谷歌Play应用市场中,超过800款Android应用感染了该恶意木马,影响数百万Android用户。感染的应用范围覆盖图片编辑器,墙纸和铃声转换器等。受感染的用户绝大多数来自亚洲东南部国家,如越南、菲律宾和印度尼西亚,美国和欧洲的感染人数较少。 对比此前恶意广告木马,Xavier的功能及特征更为复杂。首先他具备远程下载恶意代码并执行的能力。其次,它通过使用诸如字符串加密,Internet数据加密和模拟器检测等方法来保护自己不被检测到。 Xavier窃取用户数据的行为很难被发现,它有一套自我保护机制,来躲避静态和动态的检测分析。此外,Xavier还具有下载和执行其他恶意代码的能力,使它的威胁性大大增加。 Xavie进化史 joymobile Xavier是恶意广告下载家族的成员之一,它的存在已有2年时间。第一个版本被称为joymobile,出现在2015年年初。joymobile这个版本已经具备执行远程代码的能力。 除了收集和泄露用户信息,它还可以安装其他应用,并在设备root的情况下实现静默安装。 它通过远程命令和C&...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
-
Docker使用Oracle官方镜像安装(12C,18C,19C)
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS8编译安装MySQL8.0.19
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS7,8上快速安装Gitea,搭建Git服务器
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
推荐阅读
最新文章
- 设置Eclipse缩进为4个空格,增强代码规范
- CentOS7,8上快速安装Gitea,搭建Git服务器
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- CentOS8编译安装MySQL8.0.19
- Red5直播服务器,属于Java语言的直播服务器
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- CentOS7设置SWAP分区,小内存服务器的救世主
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题