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章关于变量对象的描述中,我们已经知道一个执行上下文 的数据(变量.函数声明和函数的形参)作为属性存储在变量对象中. 同时我们也知道变量对象在每次进入上下文时创建,并填入初始值,值的更新出 ...
随机推荐
- 使用ServiceStack构建Web服务
提到构建WebService服务,大家肯定第一个想到的是使用WCF,因为简单快捷嘛.首先要说明的是,本人对WCF不太了解,但是想快速建立一个WebService,于是看到了MSDN上的这一篇文章 Bu ...
- excel 日期/数字格式不生效需要但双击才会生效的解决办法
原因: Excel2007设置过单元格格式后,并不能立即生效必须挨个双击单元格,才能生效.数据行很多.效率太低. 原因:主要是一些从网上拷贝过来的日期或数字excel默认为文本格式或特殊-中文数字格式 ...
- JavaScript正则表达式,你真的知道?
一.前言 粗浅的编写正则表达式,是造成性能瓶颈的主要原因.如下: var reg1 = /(A+A+)+B/; var reg2 = /AA+B/; 上述两个正则表达式,匹配效果是一样的,但是,效率就 ...
- ubuntu如何安装nodejs最新版 本
如何正确的安装nodejs? 我们可以先安装nvm, git clone https://github.com/creationix/nvm.git ~/.nvm 然后打开 ~/.bashrc , ...
- 写出易调试的SQL
h4 { background: #698B22 !important; color: #FFFFFF; font-family: "微软雅黑", "宋体", ...
- 使用Expression实现数据的任意字段过滤(1)
在项目常常要和数据表格打交道. 现在BS的通常做法都是前端用一个js的Grid控件, 然后通过ajax的方式从后台加载数据, 然后将数据和Grid绑定. 数据往往不是一页可以显示完的, 所以要加分页: ...
- stringstream的基本用法
原帖地址:https://zhidao.baidu.com/question/580048330.htmlstringstream是字符串流.它将流与存储在内存中的string对象绑定起来.在多种数据 ...
- 深入理解css3中nth-child和 nth-of-type的区别
在css3中有两个新的选择器可以选择父元素下对应的子元素,一个是:nth-child 另一个是:nth-of-type. 但是它们到底有什么区别呢? 其实区别很简单::nth-of-type为什么要叫 ...
- Tableau未必最佳,国内BI也能突破重围!
如今,百度一下商业智能或BI工具,总能看到Tableau的身影.并不是Tableau的营销做得好,而是国内对于商业智能工具的认知和选择似乎都落在了Tableau身上.导致不管业内业外都对商业智能的概念 ...
- 驱动01.LED
1.写出leds_open,leds_write函数2.1告诉内核这几个函数的存在?定义一个结构体file_operations2.2把这个结构体告诉内核?用register_chrdev(major ...