Jetpack Compose and Room DB: Performance overhead of auto-saving user input?(Jetpack Compose和Room DB:自动保存用户输入的性能开销?)
本文介绍了Jetpack Compose和Room DB:自动保存用户输入的性能开销?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我正在编写一个使用Jetpack Compose的应用程序,该应用程序允许用户在某些TextFields
中输入文本,并选中几个单选按钮。
然后将此数据存储在Room数据库中。
目前,我在屏幕底部有一个"保存&q;"按钮,并弹出一个"离开而不保存?"(&q;)
。但是,我希望完全取消保存按钮,让它在键入数据时自动保存数据。
重复键入数据库查询是否会导致任何性能问题?对于这类事情有什么既定的最佳实践吗?
推荐答案
对于kotlin flow,您可以使用专门针对此类情况设计的debounce
。这样,只要用户输入文本,saveToDatabase
就不会被调用,当他一段时间没有输入字符时(在我的示例中是一秒),流就会发出。
另外,在合成导航过程中,如果关闭屏幕,视图模型可能会被销毁(协程将被取消),在这种情况下,我还会将数据保存在onCleared
中,以确保不会丢失任何内容。
class ScreenViewModel: ViewModel() {
private val _text = MutableStateFlow("")
val text: StateFlow<String> = _text
init {
viewModelScope.launch {
@OptIn(FlowPreview::class)
_text.debounce(1000)
.collect(::saveToDatabase)
}
}
fun updateText(text: String) {
_text.value = text
}
override fun onCleared() {
super.onCleared()
saveToDatabase(_text.value)
}
private fun saveToDatabase(text: String) {
}
}
@Composable
fun ScreenView(
viewModel: ScreenViewModel = viewModel()
) {
val text by viewModel.text.collectAsState()
TextField(value = text, onValueChange = viewModel::updateText)
}
@OptIn(FlowPreview::class)
表示接口未来可能会修改。如果您现在不想使用它,请参阅替换here。
这篇关于Jetpack Compose和Room DB:自动保存用户输入的性能开销?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:Jetpack Compose和Room DB:自动保存用户输入的性能开销?


猜你喜欢
- Android - 拆分 Drawable 2022-01-01
- 使用自定义动画时在 iOS9 上忽略 edgesForExtendedLayout 2022-01-01
- 如何检查发送到 Android 应用程序的 Firebase 消息的传递状态? 2022-01-01
- android 4中的android RadioButton问题 2022-01-01
- Android - 我如何找出用户有多少未读电子邮件? 2022-01-01
- 想使用ViewPager,无法识别android.support.*? 2022-01-01
- MalformedJsonException:在第1行第1列路径中使用JsonReader.setLenient(True)接受格式错误的JSON 2022-01-01
- 用 Swift 实现 UITextFieldDelegate 2022-01-01
- Android viewpager检测滑动超出范围 2022-01-01
- 在测试浓缩咖啡时,Android设备不会在屏幕上启动活动 2022-01-01