dagger2系列之Scope
Dagger的Scope注解代表的是作用域,通过实现自定义@Scope注解,标记当前生成对象的使用范围,标识一个类型的注射器只实例化一次,在同一个作用域内,只会生成一个实例,
然后在此作用域内共用一个实例。这样看起来很像单例模式,我们可以查看@Singleton其实就是@Scope的一个默认实现而已。当然,你得是同一个Component对象来生成
Dagger为我们提供了Scope的一种实现Singleton。单例???no!!!no!!!no!!!不是这么简单的。先看一下它的代码:
@Scope
@Documented
@Retention(RUNTIME)
public @interface Singleton {}
在Dagger中我们可以自定义注解,譬如我们可以照着上面的模版自定义一个PreScope。
@Scope
@Retention(RetentionPolicy.RUNTIME)
public @interface PreScope {
}
我们自定义的这个PreScope注解也有和Singleton同样的作用(单例)。下面看一下它的使用!!!
@Module
public class AppModule7 { private App7 app; public AppModule7(App7 app) {
this.app = app;
} @Provides
@Singleton
public App7 provideApp() {
return app;
} @Provides
@Singleton
Context provideApplicationContext() {
return app.getApplicationContext();
} } @Singleton
@Component(modules = {AppModule7.class})
public interface AppComponent7 {
void inject(App7 app); //因为AppComponent会被dependencies,所以此处Module中提供的内容,我们需要在此处声明一下
App7 getApp();
Context getApplicationContext();
}
@Module
public class ActivityModule7 { @Provides
@PreScope
public DependencyPresenter7 getDependencyPresenter(App7 app){
return new DependencyPresenter7(app);
}
} @PreScope
@Component(modules = ActivityModule7.class,dependencies = AppComponent7.class)
public interface ActivityComponent7 {
void inject(TargetActivity71 activity71);
void inject(TargetActivity72 activity72);
} public class App7 extends Application { private AppComponent7 mAppComponent7;
private ActivityComponent7 mActivityComponent7; @Override
public void onCreate() {
super.onCreate();
mAppComponent7 = DaggerAppComponent7.builder().appModule7(new AppModule7(this)).build();
mAppComponent7.inject(this);
mActivityComponent7 = DaggerActivityComponent7.builder().appComponent7(mAppComponent7).build();
} public AppComponent7 getAppComponent7(){
return mAppComponent7;
}
public ActivityComponent7 getActivityComponent7(){
return mActivityComponent7;
} } public class DependencyPresenter7 {
public DependencyPresenter7(App7 app){
Log.d("Dagger.class","DependencyPresenter7-----构造器被调用--------");
} public void printMethod(){
Log.d("Dagger.class","DependencyPresenter7-----printMethod()-----");
} } public abstract class BaseActivity712 extends Activity { private ActivityComponent7 mActivityComponent7; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
App7 app712 = (App7) getApplication();
mActivityComponent7 = app712.getActivityComponent7();
inject(mActivityComponent7);
} public abstract void inject(ActivityComponent7 activityComponent7);
} public class TargetActivity71 extends BaseActivity712 { @Inject
DependencyPresenter7 mDependencyPresenter; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); Log.d("Dagger.class","TargetActivity71---mDependencyPresenter地址值-------"+mDependencyPresenter.toString());
} @Override
public void inject(ActivityComponent7 activityComponent7) {
activityComponent7.inject(this);
} public void jump(View v){
startActivity(new Intent(this,TargetActivity72.class));
}
} public class TargetActivity72 extends BaseActivity712 { @Inject
DependencyPresenter7 mDependencyPresenter; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); Log.d("Dagger.class","TargetActivity72---mDependencyPresenter地址值-------"+mDependencyPresenter.toString());
} @Override
public void inject(ActivityComponent7 activityComponent7) {
activityComponent7.inject(this);
}
}
上面的代码我们使用了Dagger默认实现的@Singleton和自定义的@PreScope注解一起实现单例。我们之所以不只用dagger提供的Singleton而且还用自定义的,是因为我们使用的域不一样,当不同的Component有依赖依赖或包含关系的时候就不能用同样的Scope,就需要我们自定义。
下面是我在学习过程中总结的结论:
1 必须使用同一个Component对象来生成,也就是DaggerActivityComponent7.builder().build()只能执行一次。
2 Component和它的Module要使用相同的Scope。同一个Module中需要使用同样的Scope,否则相应的Component不知道使用什么Scope
3 有依赖关系或者包含关系的Component不能使用同样的Scope。
上面的三条结论就是在学习使用Singleton的时候总结出的,大家在学习的时候,最好自己也验证一下。
dagger2系列之Scope的更多相关文章
- Dagger2系列之使用方法
本系列只讲使用方法和使用中遇到的问题,如果还对dagger2还不了解的童鞋儿可以参考文章: http://www.jianshu.com/p/cd2c1c9f68d4 http://www.jians ...
- Dagger2 中的 Scope
Dagger2 中虽然概念挺多的,但是大部分花时间都能理清.包括看人家的分析,Debug 代码下去也能懂.但是对于 scope 的用法以及实现原理还是有点难理解的.主要的问题也像简书上的文章所说: 自 ...
- dagger2系列之依赖方式dependencies、包含方式(从属方式)SubComponent
本篇是实战文章,从代码的角度分析这两种方式.本文参考自下列文章: http://www.jianshu.com/p/1d42d2e6f4a5 http://www.jianshu.com/p/94d4 ...
- dagger2系列之生成类实例
上一节的最后,我讲到一次注入生成类实例的生成步骤.先来回顾一下: 1 Module中存在创建方法,则看此创建方法有没有参数 如果有参数,这些参数也是由Component提供的,返回步骤1逐一生成参数 ...
- Dagger2在Android开发中的应用
世界是普遍联系的,任何事物和个体都直接或间接相互依赖,在时空长河中共同发展.在面向对象的世界中,更是如此,类与类之间的依赖,关联关系,模块(亦或是分层架构中的层)之间的耦合关系,都是我们在软件开发实践 ...
- Android学习资源网站大全
https://github.com/zhujun2730/Android-Learning-Resources 整理了一些 Android 的博客链接.学习资源网站.站在巨人的肩膀上,会看得更远.整 ...
- 解锁Dagger2使用姿势(二) 之带你理解@Scope
关于Dagger2使用的基础如果你还不了解,可以参考我的上一篇文章解锁Dagger2使用姿势(一),这有助于你理解本篇文章. OK,我们在上篇文章介绍另外Dagger2使用过程中四个基本的注解,分别是 ...
- 补习系列(3)-springboot中的几种scope
目标 了解HTTP 请求/响应头及常见的属性: 了解如何使用SpringBoot处理头信息 : 了解如何使用SpringBoot处理Cookie : 学会如何对 Session 进行读写: 了解如何在 ...
- 深入理解JavaScript系列(14):作用域链(Scope Chain)
前言 在第12章关于变量对象的描述中,我们已经知道一个执行上下文 的数据(变量.函数声明和函数的形参)作为属性存储在变量对象中. 同时我们也知道变量对象在每次进入上下文时创建,并填入初始值,值的更新出 ...
随机推荐
- Android SwipeRefreshLayout 下拉刷新——Hi_博客 Android App 开发笔记
以前写下拉刷新 感觉好费劲,要判断ListView是否滚到顶部,还要加载头布局,还要控制 头布局的状态,等等一大堆.感觉麻烦死了.今天学习了SwipeRefreshLayout 的用法,来分享一下,有 ...
- BootStrap_02之全局样式及组件
1.BootStrap指定的四种屏幕尺寸: ①超大PC屏幕--lg(large):w>=1200px: ②中等PC屏幕--md(medium):1200px>w>=992px: ③P ...
- redis 学习笔记(2)
redis-cluster 简介 redis-cluster是一个分布式.容错的redis实现,redis-cluster通过将各个单独的redis实例通过特定的协议连接到一起实现了分布式.集群化的目 ...
- 计算机程序的思维逻辑 (60) - 随机读写文件及其应用 - 实现一个简单的KV数据库
57节介绍了字节流, 58节介绍了字符流,它们都是以流的方式读写文件,流的方式有几个限制: 要么读,要么写,不能同时读和写 不能随机读写,只能从头读到尾,且不能重复读,虽然通过缓冲可以实现部分重读,但 ...
- SQL Server 2016白皮书
随着SQL Server 2016正式版发布日临近,相关主要特性通过以下预览学习: Introducing Microsoft SQL Server 2016 e-bookSQL Server 201 ...
- 一个IT人的成长路
毕业四年多了,来深圳三年多了,经历了刚毕业的懵懂少年,成长为现在的成熟稳重青年.职场上,从刚毕业的小白,成长为现在可以成熟应对各种事情的老司机.经历过从初级研发工程师,到中级研发工程师,到高级研发工程 ...
- AspNetPager分页控件样式的使用
分页是Web应用程序中最常用到的功能之一,AspNetPager 简单实用,应用到项目后台中,棒极了! 自定义样式: <style type="text/css"> ...
- Tomcat之APR错误
在发布Apache Tomcat的时候,突然出现如下错误: An incompatible version 1.1.31 of the APR based Apache Tomcat Native l ...
- BZOJ 3110: [Zjoi2013]K大数查询 [树套树]
3110: [Zjoi2013]K大数查询 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 6050 Solved: 2007[Submit][Sta ...
- 【每日一linux命令1】linux命令路径
一.路径: 执行命令前必须要考虑的一步是命令的路径,若是路径错误或是没有正确的指定,可能导致错误 的执行或是找不到该命令.要知道设置的路径,可执行以下命令: echo $PATH 显示结果: 这时我们 ...