Dagger2 (一) 入坑篇

来源:http://www.cnblogs.com/pedro-neer/archive/2016/03/21/5303416.html
-Advertisement-
Play Games

為什麼是Dagger2 為了更好的瞭解Dagger2,請先閱讀 "RoboGuice" 篇瞭解依賴註入。 官方文檔稱,依賴註入這種技術已經在存在多年了,為什麼Dagger2要造輪子? Dagger2是第一個全部使用自動生成代碼的框架。 框架生成的代碼就像我們自己手寫的,可以輕易進行調試和測試,並且很


為什麼是Dagger2

為了更好的瞭解Dagger2,請先閱讀RoboGuice篇瞭解依賴註入。

官方文檔稱,依賴註入這種技術已經在存在多年了,為什麼Dagger2要造輪子?

Dagger2是第一個全部使用自動生成代碼的框架。

框架生成的代碼就像我們自己手寫的,可以輕易進行調試和測試,並且很容易瞭解其原理。

一.接入

Dagger2使用了生成代碼的方式,這裡需要apt的插件。

buildscript {
    repositories {
        jcenter()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:2.0.0-beta6'
        classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'
    }
}

而Dagger2的主要包中,方法則特別少,主要是編譯時提供。

dependencies {
    compile 'com.google.dagger:dagger:2.0.2'
    provided 'com.google.dagger:dagger-compiler:2.0.2'
    provided 'org.glassfish:javax.annotation:10.0-b28'
}

由此,接入框架便成功了。

二.視圖註入

相對於RoboGuice來講,Dagger2是不支持視圖註入的,所以如果選用Dagger2進行對象註入框架的話,可以考慮Dagger2+ButterKnife的配合使用,Dagger2和ButterKnife都沒有使用反射機制並且專註於對象或視圖的註入。

三.對象註入

Dagger2的對象註入同RoboGuice略有不同,但也是和其他註入框架類似,還是使用之前的例子,下麵是一個用來儲存用戶信息的model。註意Dagger2不會預設使用預設構造方法創建以來,必須手動指定。

public class UserInfo {
    private String userId;
    private String token;

    @Inject
    UserInfo(){
    }

    public String getUserId() {
        return userId;
    }

    public void setUserId(String userId) {
        this.userId = userId;
    }

    public String getToken() {
        return token;
    }

    public void setToken(String token) {
        this.token = token;
    }

    public boolean isLogin(){
        return !TextUtils.isEmpty(token);
    }
}

當我直接使用Inject這個UserInfo的對象的時候,框架會為我們預設使用構造方法進行初始化。

public class MainActivity extends AppCompatActivity {

    @Inject
    UserInfo userInfo;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        userInfo.setToken("testToken");
        userInfo.setUserId("123456");
    }
}

四.Module與Component

Dagger2相比於RoboGuice更為靈活,其中Module的定義與RoboGuice相同,主要指提供依賴的模塊,而Component則是一個新出現的詞。

Component英文原意為組件,但在這裡面就是一個註入器,相當於RoboGuice中的RoboInject,是提供依賴及使用依賴之間的橋梁,而Dagger2更為靈活的是,我們可以自定義這個註入器。

廢話不多說,上代碼。

首先我們定義一個Module,與RoboGuice不同的是,我們只需要加入註解即可,不需要繼承自Dagger2的Module類。

這裡我們提供了Application和Context的依賴。

@Module
public class ApplicationModule {

    private Application application;

    public ApplicationModule(Application application) {
        this.application = application;
    }

    @Singleton
    @Provides
    public Application application() {
        return application;
    }

    @Singleton
    @Provides
    public Context context() {
        return application;
    }
}

接下來定義另一個Module,GsonModule。

還是熟悉的標有需要serializeNulls的Gson對象。

@Module
public class GsonModule {

    @Provides
    public Gson provideGson() {
        return new GsonBuilder().
                serializeNulls().
                create();
    }
}

接下來我們定義一個註入器,ApplicationComponent。

定義方法也很簡單,註解標有Component,並且可以指定註入器可以註入的模塊。

其中inject方法稍後講解。

@Component(modules = {ApplicationModule.class, GsonModule.class})
public interface ApplicationComponent {
    void inject(MainActivity activity);
}

好了,寫到這,可以放心大膽的編譯一下項目了,這時Dagger2會自動生成一些代碼,生成的代碼是Component前加上Dagger的類,上面的例子生成的就是DaggerApplicationComponent。

如何使用註入呢?我們用以下方法初始化這個註入器ApplicationComponent。

public class DaggerApplication extends Application {

    private static ApplicationComponent component;

    @Override
    public void onCreate() {
        super.onCreate();
        component = DaggerApplicationComponent.builder().
                applicationModule(new ApplicationModule(this)).
                gsonModule(new GsonModule()).
                build();
    }

    public static ApplicationComponent Component() {
        return component;
    }
}

這裡只相當於註入器的初始化,並沒有真正的註入對象,下麵我們在MainActivity中註入對象。

public class MainActivity extends AppCompatActivity {

    @Inject
    Context context;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        component().inject(this);
        Log.e(TAG, "onCreate: " + context.getPackageName());
    }

    public ApplicationComponent component() {
        return DaggerApplication.Component();
    }
}

運行一下,可以看到列印出了日誌,至此,我們第一個較為複雜的註入就完成了。這裡註入的其實是Application的Context,並不是Activity的Context,為什麼呢,以為我們在Application的Module中定義了Context的Provider。

03-20 22:51:25.046 32476-32476/github.pedroneer.dagger2 E/MainActivity: onCreate: github.pedroneer.dagger2

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Firebug功能異常強大,不僅可以調試DOM,CSS,還可以調試JS代碼,下麵介紹一下調試JS。 console對象是Firebug內置的對象,該對象可以在代碼中寫入,可以在控制面板中寫入。 1)有五個方法來顯示信息。依次為: 1、console.log(),可以用來取代alert()或docum
  • 之前計劃是一周還原一個網頁或者切一張psd來練習基本功的。正好周五的時候接到一個電話面試,讓我還原一下163郵箱主頁,晚上發給他,就正好當是這周的練習吧。 吃完晚飯開工,做到12點,差不多4個小時,基本上做完了,不過還有些局部沒完成。算還原度90%吧,剩下的這兩天有空再補啦。 這是目前的完成情況 w
  • 最近在學習NodeJS,用到了express,看著官網上的API手冊,打算把其中比較常用到的API根據自己理解翻譯一下,方便自己學習使用. 該篇打算用來記錄下express中res. 由於水平有限,希望能得到大家的修改,在學習過程中我會持續更新修改 Response res對象表示的是Express
  • 常用正則表達式大全!(例如:匹配中文、匹配html) 匹配中文字元的正則表達式: [u4e00-u9fa5] 評註:匹配中文還真是個頭疼的事,有了這個表達式就好辦了 匹配雙位元組字元(包括漢字在內):[^x00-xff] 評註:可以用來計算字元串的長度(一個雙位元組字元長度計2,ASCII字元計1) 匹
  • web前端開發-編寫高性能JavaScript 很多JavaScript引擎,如Google的V8引擎(被Chrome和Node所用),是專門為需要快速執行的大型JavaScript應用所設計的。如果你是一個開發者,並且關心記憶體使用情況與頁面性能,你應該瞭解用戶瀏覽器中的JavaScript引擎是如
  • 之前本來打算在寫兩個篇幅,但是在這片開寫的時候覺得還是寫一個比較好,有利於理解。NSURLSession下載是通過NSURLSession下載代理實現的,上一片也介紹了代理,之所以沒有介紹下載是因為,我個人覺得容易混淆(應該是我太笨)。這篇隨筆里將會介紹NSURLSession下載的實現,包括下載的
  • 一、已有類型的歸檔和解檔 首先來看一個簡單的例子: //第二種方式 //第一種方式的缺陷是一個對象歸檔成一個文件 //但是第二種方式,多個對象可以歸檔成一個文件 NSArray *array = [NSArray arrayWithObjects:@"zhangsan",@"lisi", nil];
  • 只有第一次運行程式才出現 ,刪除重新運行程式才會有。 我只展示最後一張圖了。 首先創建一個viewcontroller的類 然後在APPDelegate中設為根視圖 然後在 UseGuideViewController.h中寫 FirstViewController是我的主界面。 巨集定義寬和高 下麵
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...