Dagger 2 系列(三) -- 基础篇:@Module 和

作者: GYLEE | 来源:发表于2018-05-31 11:58 被阅读17次
    Dagger2

    在这篇文章中你会看到什么:

    • @Module 是什么 ?
    • @Provides 是什么 ?
    • @Module@Provides@Component 如何协同作战。

    @Module

    既然在Dagger 2 系列(二) -- 基础篇:基本功能的实现一文中通过 @Inject@Component 我们已经实现了 DI,那么为什么 Dagger2 还要实现其他的DI 方式。
    其实在上文中我们实现的 DI 方式中我们不难发现,通过@Inject 的注解实体类的构造函数是必不可少,它标识着 Dagger2 可以实例化该类。那么当你需要实例化一个第三方的对象时,是不是懵逼了,要实现注解该类的构造函数,这是不可能的。那么现在就需要 @Module 来充分发挥作用了。其实Module 其实是一个简单工厂模式,Module 里面的方法都是创建相应类实例的方法。

    具体什么是 简单工厂模式,请看代码段简单学习设计模式 -- 简单工厂模式

    栗子:通过 @Module 的方式获得第三方类库的对象 -- Gson(当然也可以获得自定义类对象)

    @Module
    public class AModule {
    
        @Provides
        public Gson provideGson(){
            return new Gson();
        }
    }
    

    你应该看到的是:

    1. 类通过 @Module 注解
    2. 方法通过 @Provides 注解

    @Provides

    在上面的栗子中出现了依着新的注解 -- @Provides,@Provides 的作用:标注 Module 中能够提供实例化对象的方法

    @Component

    此时 DI 不是通过 @Inject 注解类构造器的方式,那么这个注解器的使用方法肯定也有所变化。此时 Component 的职责是管理 Module,Component 中的属性可以把Module加入到 Component,同时一个Component可以加入多个 Module。
    具体工作流程:


    协作流程

    代码示例

    @Component(modules = UserTwoModule.class)
    public interface UserTwoComponent {
        void injectToSecondActivity(SecondActivity mSecondActivity);
    }
    
    @Module
    public class UserTwoModule {
        @Provides
        UserTwo provideUserTwo(){
            return new UserTwo("男",1243);
        }
    }
    
    public class SecondActivity extends AppCompatActivity {
        @Inject
        UserTwo mUserTwo;
        private static final String TAG = "SecondActivity";
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_second);
         DaggerUserTwoComponent.builder().userTwoModule(new UserTwoModule()).build().injectToSecondActivity(this);
        }
    }
    
    

    Dagger2 sample github地址

    总结

    到此为止,我们已经实现了基本的基于Dagger2@Module@Provides的依赖注入。下面我们把过程再梳理一遍:

    1. 用@Inject注解标注目标类中其他类
    2. Module 中创建返回值为相应实体类的方法,并用 @Provides 标注
    3. 若其他类还依赖于其他的类,则重复进行上面2个步骤
    4. 调用Component(注入器)的injectXXX(Object)方法开始注入(injectXXX方法名字是官方推荐的名字,以inject开始)

    Component 就像媒介,连接 Module目标类,把目标类依赖的实例注入到目标类中,来初始化目标类中的依赖。

    参考文章


    Dagger 详解
    Dagger2 入门实践
    Android:dagger2让你爱不释手-基础依赖注入框架篇
    Android:dagger2让你爱不释手-终结篇
    最简单的Dagger2入门教程
    这就是Dagger2

    相关文章

      网友评论

        本文标题:Dagger 2 系列(三) -- 基础篇:@Module 和

        本文链接:https://www.haomeiwen.com/subject/ibqqsftx.html