Android--Dagger入门浅析

2024-04-08 07:32
文章标签 android 入门 浅析 dagger

本文主要是介绍Android--Dagger入门浅析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一:什么是Dagger?
是一个依赖注入框架
—-依赖注入是面向对象编程的一种设计模式,其目的是为了降低程序耦合,这个耦合就是类之间的依赖引起的!

二:
写面向对象程序时,往往会用到组合,即在一个类中引用另一个类,从而可以调用引用的类的方法完成某些功能:

public class ClassA {ClassB classB;public ClassA(){classB=new ClassB();}public void todo(){classB.dosomething();}
}

此时就产生了依赖问题,ClassA依赖于ClassB,必须借助ClassB的方法才能完成一些功能。在ClassA里直接创建ClassB实例,违背了单一职责原则,ClassB实例的创建不应由ClassA来完成;其次耦合度增加,扩展性差,如果我们想在实例化ClassB的时候传入参数,那么不得不改动ClassA的构造方法,不符合开闭原则。

因此需要一种解决方案,将依赖注入到宿主类(或者叫目标类)中,从而解决上面所述的问题!
依赖注入有一下几种方式:
—-1:接口

public interface IClassB {void setB(ClassB b);
}
public class ClassA implements IClassB {ClassB classB;@Overridepublic void setB(ClassB b) {classB = b;}}

—-2:Set方法

public class ClassA {ClassB classB;public void setB(ClassB b) {classB = b;}
}

—-3:构造函数

public class ClassA{ClassB classB;public ClassA(ClassB b){classB=b;}}

—4:通过JAVA注解:

public class ClassA{@InjectClassB classB;}

而Dagger注解的作用就相当于帮我们完成了不同情况下的 ClassA a=new ClassA(……..);

三:as配置:

app–build.gradle:

apply plugin: 'com.neenbedankt.android-apt'
compile 'com.google.dagger:dagger:2.2'
apt 'com.google.dagger:dagger-compiler:2.2'

gradle–build.gradle:

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

四:
Dagger是基于MVP模式下的注解框架,请先熟悉MVP:
先熟悉一下一个例子:
—-1:JAVABean:

public class User {private String name;private String phone;public String getName() {return name;}public void setName(String name) {this.name = name;}public String getPhone() {return phone;}public void setPhone(String phone) {this.phone = phone;}
}

—-2:

@ActivityScope
@Component(modules = {MainActivityModule.class})
public interface MainActivityComponent {void inject(MainActivity mainActivity);
}

—-3:

@Module
public class MainActivityModule {private MainActivityContract.View view;private Context context;public MainActivityModule(MainActivityContract.View view, Context context) {this.view = view;this.context = context;}@ActivityScope@Providespublic LoginPresenter getMainActivityPresenter() {return new LoginPresenter(context, view);}
}

—-4:

public interface BasePresenter {}

—-5:

public interface BaseView<T> {}

—-6:

public class LoginPresenter implements MainActivityContract.Presenter {public Context context;public MainActivityContract.View view;public LoginPresenter(Context context, MainActivityContract.View view) {this.context = context;this.view = view;}@Overridepublic void showUser() {User user = view.getUser();Toast.makeText(context, "user" + user.getPhone() + user.getName(), Toast.LENGTH_LONG).show();}
}

—-7:

public interface MainActivityContract {interface Presenter extends BasePresenter {void showUser();}interface View extends BaseView<Presenter> {User getUser();}
}

—-8:
自定义注解:生命周期和Activity周期保持一致

@Scope
@Retention(RetentionPolicy.RUNTIME)
public @interface ActivityScope {
}----9@Qualifier
@Documented
@Retention(RetentionPolicy.RUNTIME)
public @interface StringNamed {String value();
}

—-10:

public abstract class BaseActivity extends AppCompatActivity {@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);providers();}public abstract void providers();
}

—-11:

@Singleton
public class MainActivity extends BaseActivity implements MainActivityContract.View {@InjectLoginPresenter presenter;@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);ButterKnife.bind(this);}@Overridepublic void providers() {DaggerMainActivityComponent.builder().mainActivityModule(new MainActivityModule(this, this)).build().inject(this);}@Overridepublic User getUser() {User user = new User();user.setName("key");user.setPhone("hello");return user;}@OnClick({R.id.button})public void Click(View view) {switch (view.getId()) {case R.id.button:presenter.showUser();break;default:break;}}}

这篇关于Android--Dagger入门浅析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/884944

相关文章

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

Android ClassLoader加载机制详解

《AndroidClassLoader加载机制详解》Android的ClassLoader负责加载.dex文件,基于双亲委派模型,支持热修复和插件化,需注意类冲突、内存泄漏和兼容性问题,本文给大家介... 目录一、ClassLoader概述1.1 类加载的基本概念1.2 android与Java Class

从入门到精通MySQL联合查询

《从入门到精通MySQL联合查询》:本文主要介绍从入门到精通MySQL联合查询,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下... 目录摘要1. 多表联合查询时mysql内部原理2. 内连接3. 外连接4. 自连接5. 子查询6. 合并查询7. 插入查询结果摘要前面我们学习了数据库设计时要满

从入门到精通C++11 <chrono> 库特性

《从入门到精通C++11<chrono>库特性》chrono库是C++11中一个非常强大和实用的库,它为时间处理提供了丰富的功能和类型安全的接口,通过本文的介绍,我们了解了chrono库的基本概念... 目录一、引言1.1 为什么需要<chrono>库1.2<chrono>库的基本概念二、时间段(Durat

解析C++11 static_assert及与Boost库的关联从入门到精通

《解析C++11static_assert及与Boost库的关联从入门到精通》static_assert是C++中强大的编译时验证工具,它能够在编译阶段拦截不符合预期的类型或值,增强代码的健壮性,通... 目录一、背景知识:传统断言方法的局限性1.1 assert宏1.2 #error指令1.3 第三方解决

从入门到精通MySQL 数据库索引(实战案例)

《从入门到精通MySQL数据库索引(实战案例)》索引是数据库的目录,提升查询速度,主要类型包括BTree、Hash、全文、空间索引,需根据场景选择,建议用于高频查询、关联字段、排序等,避免重复率高或... 目录一、索引是什么?能干嘛?核心作用:二、索引的 4 种主要类型(附通俗例子)1. BTree 索引(

Redis 配置文件使用建议redis.conf 从入门到实战

《Redis配置文件使用建议redis.conf从入门到实战》Redis配置方式包括配置文件、命令行参数、运行时CONFIG命令,支持动态修改参数及持久化,常用项涉及端口、绑定、内存策略等,版本8... 目录一、Redis.conf 是什么?二、命令行方式传参(适用于测试)三、运行时动态修改配置(不重启服务

浅析如何保证MySQL与Redis数据一致性

《浅析如何保证MySQL与Redis数据一致性》在互联网应用中,MySQL作为持久化存储引擎,Redis作为高性能缓存层,两者的组合能有效提升系统性能,下面我们来看看如何保证两者的数据一致性吧... 目录一、数据不一致性的根源1.1 典型不一致场景1.2 关键矛盾点二、一致性保障策略2.1 基础策略:更新数

Android DataBinding 与 MVVM使用详解

《AndroidDataBinding与MVVM使用详解》本文介绍AndroidDataBinding库,其通过绑定UI组件与数据源实现自动更新,支持双向绑定和逻辑运算,减少模板代码,结合MV... 目录一、DataBinding 核心概念二、配置与基础使用1. 启用 DataBinding 2. 基础布局