1、@Singleton (可以用來表示全局單例) @Scope(可以用來表示局部單例)
當Component的Modules中有@Singleton標記的Provide方法,當前Component也必須用@Singleton標記。由于Singleton也是被@Scope所標記,所以同理被@Scope標記的Provide方法,Component也需要被標記。
@Component的dependencies與@Component自身的scope不能相同,即組件之間的scope不能相同.
@Singleton的組件不能依賴其他scope的組件,但是其他scope的組件可以依賴@Singleton組件
@Singleton實現全局單例的方式比較特殊,必須滿足以下幾個條件:
(1)全局單例AppComponent必須保證只被實例化一次。
(2)即使AppComponent只在Application中實例化一次,也得保證Module中的Provide方法被@Singleton標記。同理,即使Module中的Provide方法與AppComponent都被@Singleton標記,也得保證AppComponent只有一個實例。
最后網上很多博客講@Singleton并沒有創建單例的能力,我認為這句話欠妥,因為即使AppComponent只在Application中實例化一次,也得保證Module中的Provide方法被@Singleton標記才能實現單例,否則client每次獲取依賴都是創建一個新的對象。
其次我認為自定義@Scope的作用有兩點:
第一:為了更好的管理Component與Module之間的組織方式,提高可讀性,能讓我們立馬就能區分哪些是全局單例,哪些是局部單例。
第二:被@Scope標記的依賴與component的生命周期(不是整個應用)關聯。可以參考下面文章。
參考:解鎖Dagger2使用姿勢(二) 之帶你理解@Scope
從Dagger2源碼角度理解Scope注解
詳解 Dagger2 的 @Scope 和 @Subcomponent
疑慮:自定義@Scope標記后,client被銷毀后,@Scope生命周期如何結束???
Dagger2的@Scope的用法介紹 這篇文章最后解決了這個疑慮
2.Dagger2添加依賴,以及版本號
// Add Dagger dependencies
dependencies {
compile 'com.google.dagger:dagger:2.x' // Dagger2 實際上是java中使用的
annotationProcessor 'com.google.dagger:dagger-compiler:2.x' // 注解處理器(這個是必須要的)
}
If you're using classes in dagger.android you'll also want to include:
compile 'com.google.dagger:dagger-android:2.x' // Dagger2 Android包
// 如果使用支持包, 上面的Android包可以省略,支持包里面已經包含了
compile 'com.google.dagger:dagger-android-support:2.x' // Dagger2 Android 支持包,用于支持v4、v7下的控件
annotationProcessor 'com.google.dagger:dagger-android-processor:2.x'
2.x中的x表示多少?可以參考https://github.com/google/dagger/releases
注意添加以上Dagger2依賴會有個編譯錯誤如圖:
解決方法:
androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
exclude group: 'com.android.support', module: 'support-annotations'
exclude group: 'com.google.code.findbugs', module: 'jsr305' //添加這一行
})
網上關于Dagger2的博客一般都是按java中的使用方法,這樣是很不方便的,在Android中的使用可以參考
Android項目基本架構(二) Dagger2
Dagger2 與 AndroidInjector