<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                企業??AI智能體構建引擎,智能編排和調試,一鍵部署,支持知識庫和私有化部署方案 廣告
                # 前言 如果您對dagger2的概念,整個依賴注入框架還不清楚,可以先了解下我的前2篇文章: [Android:dagger2讓你愛不釋手-基礎依賴注入框架篇](http://www.jianshu.com/p/cd2c1c9f68d4) [Android:dagger2讓你愛不釋手-重點概念講解、融合篇](http://www.jianshu.com/p/1d42d2e6f4a5) 這2篇文章也收到好多網友的好評和提問,謝謝大家的支持。我大概總結了下提的問題: * dagger2到底能帶來哪些好處? * dagger2怎么使用? 因此我將結合這2點來進行本文的講解。并且會有具體的sample。 # dagger2到底有哪些好處? 咱們直奔主題: **增加開發效率、省去重復的簡單體力勞動** 首先new一個實例的過程是一個重復的簡單體力勞動,dagger2完全可以把new一個實例的工作做了,因此我們把主要精力集中在關鍵業務上、同時也能增加開發效率上。 省去寫單例的方法,并且也不需要擔心自己寫的單例方法是否線程安全,自己寫的單例是懶漢模式還是餓漢模式。因為dagger2都可以把這些工作做了。 **更好的管理類實例** 每個app中的ApplicationComponent管理整個app的全局類實例,所有的全局類實例都統一交給ApplicationComponent管理,并且它們的生命周期與app的生命周期一樣。 每個頁面對應自己的Component,頁面Component管理著自己頁面所依賴的所有類實例。 因為Component,Module,整個app的類實例結構變的很清晰。 **解耦** 假如不用dagger2的話,一個類的new代碼是非常可能充斥在app的多個類中的,假如該類的構造函數發生變化,那這些涉及到的類都得進行修改。設計模式中提倡把**容易變化的部分封裝起來**。 我們用了dagger2后。 假如是通過用Inject注解標注的構造函數創建類實例,則即使構造函數變的天花亂墜,我們基本上都不需要修改任何代碼。 假如是通過**工廠模式**Module創建類實例,Module其實就是把new類實例的代碼封裝起來,這樣即使類的構造函數發生變化,只需要修改Module即可。 有個網友問過一個這樣的問題,Module的構造函數也會發生變化,發生變化后,相應的new Module的類也發生變化,這就沒有達到解耦的效果。首先解耦不是說讓類之間或模塊之間真的一點關系都沒有了,解耦達到的目的是讓一個類或一個模塊對與自己有關聯的類或模塊的影響降到最低,不是說這種影響就完全沒有了,這是不可能的。 解耦還有個好處,就是方便測試,若需要替換為網絡測試類,只需要修改相應的Module即可。 # 項目中使用dagger2注意點 具體的代碼就不講了,[dagger2 sample地址](https://github.com/niuxiaowei/Dagger2Sample.git),大家自行下載。這里重點說下dagger2對目標類進行依賴注入的過程,現在假設要初始化目標類中的其中一個依賴類的實例,那具體步驟就在下面: ~~~ 步驟1:查找Module中是否存在創建該類的方法。 步驟2:若存在創建類方法,查看該方法是否存在參數 步驟2.1:若存在參數,則按從**步驟1**開始依次初始化每個參數 步驟2.2:若不存在參數,則直接初始化該類實例,一次依賴注入到此結束 步驟3:若不存在創建類方法,則查找Inject注解的構造函數, 看構造函數是否存在參數 步驟3.1:若存在參數,則從**步驟1**開始依次初始化每個參數 步驟3.2:若不存在參數,則直接初始化該類實例,一次依賴注入到此結束 ~~~ 以上是dagger2進行的一次依賴注入的步驟,其實這個步驟是一個遞歸的過程,并且在查找類的實例的過程中Module的級別要高于Inject,這概念在[上一篇](http://www.jianshu.com/p/1d42d2e6f4a5)講過。 **下面在說下注意的幾點** * 一個app必須要有一個Component(名字可以是ApplicationComponent)用來管理app的整個全局類實例 * 多個頁面可以共享一個Component * 不是說Component就一定要對應一個或多個Module,Component也可以不包含Module * 自定義Scope注解最好使用上,雖然不使用也是可以讓項目運行起來的,但是加上好處多多。 # 總結 好了關于dagger2的所有的概念知識點到此終于結束了,希望能幫助大家,與大家共勉,有問題可以隨時與我溝通。 [dagger2 sample地址](https://github.com/niuxiaowei/Dagger2Sample.git) **個人簡介** 本人是一名android開發工程師,開發android多年,若有志同道合的朋友想聯系我,可以加我的:qq/微信: 704451290 作者:牛曉偉 鏈接:http://www.jianshu.com/p/65737ac39c44 來源:簡書 著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看