Dagger2---用户引导(翻译)

原文链接:http://google.github.io/dagger/users-guide.html
从Why Dagger 2 is Different 开始翻译。

为什么Dagger2是不同的

依赖注入的框架在几年前就已经存在了,有许多中API实现了依赖和注入。为什么要重复造轮子呢?Dagger2是第一个实现了全部代码生成。它的目标原则是模仿用户那些手写的代码(实现依赖注入的代码)使依赖注入的过程实现起来更加简单。

使用Dagger2

我们将通过CoffeeMaker的例子证明Dagger的依赖注入。已经完成的代码可以从coffee example查看,并进行编译和运行。

声明依赖

使用Dagger为你的应用类构造实例,并且满足它们的依赖。Dagger使用 javax.inject.Inject
注解标明哪些构造方法和参数是需要注解的。
使用@Inject注解一个构造方法表示应该用Dagger为这个类创建一个实例。当一个请求为该对象创建一个新的实例时,Dagger会获得请求的参数值然后执行该构造方法。

class Thermosiphon implements Pump { 
     private final Heater heater;
     @Inject 
     Thermosiphon(Heater heater) { 
         this.heater = heater; 
     }
 ...
}

Dagger也可以直接注解参数,在这个例子中将为一个heater对象获得一个 Heater实例,为pump对象获得一个Pump实例。

class CoffeeMaker { 
@Inject 
Heater heater; 
@Inject
Pump pump;
 ...}

如果你用@inject标注了参数,但没有用@inject标注方法。当有请求到这些参数的时候,Dagger会为这些对象提供注入,但不会为他们创建实例。用@inject标注一个无参的构造函数,以表明Dagger也可以创建一个实例。
Dagger同样也支持方法的注入,尽管通常情况下优先考虑的是参数和构造方法。
如果一个类缺乏@Inject是不能通过Dagger构建的

满意的依赖

默认情况下,Dagger通过构造请求类型对象的实例满足每一个依赖。像上面描述(例子)的那样,当你请求(需要)一个CoffeeMaker对象,你将通过调用new Caffee()对象获得一个对象,注入到可以注入的参数中。
但是@Inject不是任何对象都可以标记的

  • interface是不能被构建的
  • 第三方的类不能被注解
  • 通过配置得到的对象,仍然必须通过配置得到(Builder模式构造的对象)

在这些情况下,@Inject是不足的(尴尬的),但是可以通过使用@Provide注解标注的方法来满足依赖,这个方法的返回值的来满足那些依赖。

就像下面这样:当需要一个Heater对象时provideHeater()方法会被执行。

@Provides 
static Heater provideHeater() { 
    return new ElectricHeater();
}

@Provides同样可以为它自己提供依赖,当我们需要一个Pump对象时,下面这个例子返回一个Thermosiphon对象时

@Provides 
static Pump providePump(Thermosiphon pump) {
  return pump;
}

所有被标注了@Provides注解的方法必须要属于一个module类(模块),这仅仅需要一个类被@module注解标注。

@Module
class DripCoffeeModule { 
@Provides
 static Heater provideHeater() { 
    return new ElectricHeater();
 } 
@Provides 
static Pump providePump(Thermosiphon pump) {
    return pump; 
 }
}

注:通常@Provides标注的方法名都拥有provide前缀,@Module标注的类都有一个叫做Module的后缀。

构建对象关系图

@Inject注解和@Provides注解类由他们之间的依赖关系形成了对关系的图,通过一组定义好的关系图调用代码就像使用应用程序的main方法或者Android的应用程序访问。它的定义是通过一个接口:具备无参的方法和需要的返回值类型。通过使用@component注解去标注这样一个接口和通过module参数去配置module类型,Dagger2随后会生成一个符合的实现。

@Component(modules = DripCoffeeModule.class)
interface CoffeeShop { 
   CoffeeMaker maker();
}

Dagger2会自动为它生成实现类,实现的名字是具有Dagger的前缀加上接口的名称。通过使用builder方法获得实例。调用Builder方法配置依赖,调用build方法获得实例。

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

推荐阅读更多精彩内容