PreferencesDataStore简单使用

导包

implementation "androidx.datastore:datastore-preferences:1.0.0"

简单使用

object SpUtil {
    val dataStore: DataStore<Preferences> = PreferenceDataStoreFactory.create {
        File(App.instance.filesDir, "aaa.preferences_pb")
    }

    private inline fun <reified T> readValue(key: String): Flow<T>? {
        val keys = getKey(key, T::class.java)
        return dataStore.data.map { it[keys] } as Flow<T>?
    }

    private suspend inline fun <reified T> putValue(key: String, value: T) {
        dataStore.edit {
            val keys = getKey(key, T::class.java) as Preferences.Key<T>
            it[keys] = value
        }
    }

    private inline fun <reified T> getKey(key: String, clazz: Class<T>): Preferences.Key<*> {
        return when (clazz) {
            Int::class -> intPreferencesKey(key)
            String::class -> stringPreferencesKey(key)
            Double::class -> doublePreferencesKey(key)
            Float::class -> floatPreferencesKey(key)
            Boolean::class -> booleanPreferencesKey(key)
            else -> stringPreferencesKey(key)
        }
    }
    
    suspend fun getAccount(): String {
        return readValue<String>("account")?.first() ?: ""
    }

    suspend fun login(account: String) {
        putValue("account", account)
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DataStore是一个新的异步API,用于在Kotlin中存储和读取数据。它使用Kotlin协程和Flow来实现异步操作,并在单独的线程上运行,从而保证了线程安全性。DataStore提供了结构化的错误处理、类型安全以及存储自定义复杂或大型数据类对象的支持。 要使用DataStore,首先需要获取DataStore对象。可以通过使用Kotlin委托来实现,具体如下所示: ```kotlin private val settingsDataStore by preferencesDataStore(name = "app_settings") ``` 在上述代码中,`settingsDataStore`是一个DataStore对象,它使用了`preferencesDataStore`委托来获取。`name`参数指定了DataStore的名称,可以是任何字符串,例如"app_settings"或包名称等。 一旦获取了DataStore对象,就可以使用它来读取和写入数据。以下是一些示例代码: ```kotlin // 写入数据 settingsDataStore.edit { settings -> settings[KEY_NAME] = "John" settings[KEY_AGE] = 25 } // 读取数据 val nameFlow: Flow<String?> = settingsDataStore.data.map { settings -> settings[KEY_NAME] } // 监听数据变化 settingsDataStore.data .map { settings -> settings[KEY_AGE] } .distinctUntilChanged() .onEach { age -> // 处理数据变化 } .launchIn(lifecycleScope) ``` 上述代码中,`edit`函数用于写入数据,`data`属性用于读取数据。可以使用`map`和`distinctUntilChanged`等函数对数据进行转换和过滤。`launchIn`函数用于在协程作用域中启动数据监听。 总结一下,DataStore是一个用于存储和读取数据的异步API,它提供了线程安全、结构化的错误处理、类型安全以及存储自定义复杂或大型数据类对象的支持。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值