我对Dagger还是比较陌生,而我刚开始使用Hilt。我想要的是将应用程序级存储库(意味着它在任何地方都必须是同一对象)注入ViewModel
。该存储库将用于检索用户,身份验证令牌和类似内容。这是我能得到的最接近的:
@Module
@InstallIn(ApplicationComponent::class)
abstract class ApplicationModule {
@Singleton
@Binds
abstract fun bindUserService(
userRepository: UserRepository
): UserService
}
@Singleton
class UserRepository @Inject constructor(
) : UserService {
private var _user: User? = null
override fun getUser(): Observable<User> {
return if (_user == null) {
fetchUser()
} else {
Observable.just(_user)
}
}
private fun fetchUser(): Observable<User> {
return Observable.just(User("foo", Random.nextDouble(100.00)))
.delay(2, TimeUnit.SECONDS)
.doOnEach { _user = it.value }
}
}
class ProfileViewModel @ViewModelInject constructor(
private val userService: UserService,
@Assisted private val savedStateHandle: SavedStateHandle
) : ViewModel() {
val user: MutableLiveData<User> by lazy {
MutableLiveData<User>()
}
fun init() {
userService.getUser().observeOn(AndroidSchedulers.mainThread()).subscribe { user.apply { value = it } }
}
}
这样,一切正常,使用调试,我可以确认每次ViewModel
使用时UserRepository
都注入的相同实例。的问题是,_user
为null
(例如,视图被破坏并重新创建)在第二时间getUser()
被调用。我不知道我是在Kotlin方面犯了一些愚蠢的错误,还是在Hilt方面犯了一个愚蠢的错误。
知道发生了什么吗?
在您的情况下,doOnEach
调用whenonSuccess
和onComplete
它表示调用了2次,第二次it.value
为null,_user
然后null
再次指定。不是来自Hilt
private fun fetchUser(): Observable<User> {
return Observable.just(User("foo", Random.nextDouble(100.00)))
.delay(2, TimeUnit.SECONDS)
.doOnEach { _user = it.value }
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句