4

我对 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 方面犯了一个愚蠢的错误。

知道发生了什么吗?

4

1 回答 1

1

在您的情况下doOnEach调用 when onSuccessonComplete这意味着它调用了 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 }
    }
于 2020-08-19T10:20:36.357 回答