初学Dagger之Hello Dagger(0)

写作背景
这几天在学习Dagger、MVP、Agera,这里所说的Dagger即Google接手的Dagger,也被称作Dagger 2。跟着demo与一些技术博客学习,发现对于一个未曾使用过类似框架的人来说上手很困难,因此撰 初学Dagger 系列学习笔记,以一名初学者的视角来分享自己的学习经验,希望让大家上手更顺利。本文集将随Winter的学习进度更新。

Hello Dagger

环境配置
我比较喜欢从功能入手来了解一个框架,所以让我们从Hello Dagger开始吧。

用 Android Studio 新建一个项目,选择 Empty Activity

如上图,新建一个项目 Hello Dagger, 选择 Empty Activity 模版。项目创建好后,在build.gradle(Project: HelloDagger)文件中的dependencies内添加

 classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'

在build.gradle(Module: app)文件中最外层的上方添加

apply plugin: 'com.neenbedankt.android-apt'

继续在该文件内的dependencies内添加

// apt command comes from the android-apt plugin
apt 'com.google.dagger:dagger-compiler:2.2'
compile 'com.google.dagger:dagger:2.2'
provided 'javax.annotation:jsr250-api:1.0'

这样,Dagger的环境便配置好了,下面让我们来开心地实现Hello Dagger.

代码实现
官方的例子有点复杂,我表示看起来很吃力,所以,这里我们实现一个最简单的Dagger demo就好了: 点击按钮,获取Dagger注解的一个String,并显示Toast。
首先,在activity_main布局中添加一个按钮, 用于触发事件,如下:

<Button
android:id="@+id/button"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:text="Say hello"/>

然后创建建一个类文件 AppModule

@Module
public class AppModule {
@Provides
String provideHello() {
return "hello dagger";
}
@Provides
@Named("hi")
String provideHi() {
return "hi dagger";
}
}

@Module : 依赖的提供者,通俗的说就是该类负责提供数据内容;
@Provides : 负责提供值,被注解的方法提供返回参数类型的数据,如果同一个module中多个provides返回参数类型一致,那么必须加@Named("xxx")以进行区分,其实xxx才是该provides的真正名字,方法名没有什么意义。
再来创建一个接口文件 AppComponent

@Component(modules = {AppModule.class})
public interface AppComponent {
void inject(MainActivity activity);
}

@Component :依赖的注入者,AppComponent在编译时会自动生成 DaggerAppComponent文件,因为modules = {AppModule.class},所以DaggerAppComponent可以访问AppModule.class内的内容,接口内有方法 void inject(MainActivity activity) ,所以该接口也可以访问MainActivity,因而可以成为MainActivity与AppModule.class之间的桥梁。
先编译一下,使AppComponent生成DaggerAppComponent文件,接着在MainActivity的onCreate()方法内添加以下代码

DaggerAppComponent.builder()
.appModule(new AppModule())
.build()
.inject(this);

这样一来,AppModule内的内容便注入到MainActivity中了,现在我们可以在MainActivity中访问AppModule里面的内容了,访问方式如下,在MainActivity中添加全局变量

@Inject
String hello;
@Inject
@Named("hi")
String hi;

@Inject :需要注入依赖的地方,Dagger 会构造一个该类的实例并满足它所需要的依赖,通俗地说就是该变量被初始化为AppModule中@Provides且同类型同名(@Named相同)的方法的返回值了。
感觉还是挺神奇,这里为了方便把注入写在MainActivity中了,如果在Application中注入,那么仅需初始化一次,该Application下的所有类都能访问了。
好了,为按钮添加点击事件,并showToast看看。
Demo地址如下:
https://github.com/XunMengWinter/HelloDagger

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,362评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,330评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,247评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,560评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,580评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,569评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,929评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,587评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,840评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,596评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,678评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,366评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,945评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,929评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,165评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,271评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,403评论 2 342

推荐阅读更多精彩内容