gpt4 book ai didi

android - Room - 后台查询慢

转载 作者:太空狗 更新时间:2023-10-29 13:48:27 25 4
gpt4 key购买 nike

我目前正在实现 Room 来替换我的旧 SQL 代码,但我遇到了一个问题,即我的查询在后台运行时非常慢。

例如,我有两个相同的查询,一个在 UI 线程上运行,另一个返回 Single。我正在使用 allowMainThreadQueries() 来测试这种情况。

    @Query("SELECT * FROM event ORDER BY `begin` ASC LIMIT $LIMIT")
fun getUIThreadSchedule(): List<Event>


@Query("SELECT * FROM event ORDER BY `begin` ASC LIMIT $LIMIT")
fun getSchedule(): Single<List<Event>>

现在,当我运行这两个程序并比较给出结果的时间时,它们非常不同。

这将需要大约 6 毫秒才能完成。

    val events = database.getUIThreadSchedule()

这将需要大约 360 毫秒才能完成。

    database.getSchedule()
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe({
// elements are now here
}, {
// show an error view
})

我尝试使用其他选项,例如 Flowable,但结果是一样的。

有谁知道我可能做错了什么?

谢谢。

最佳答案

在对问题进行大量调查后,我发现了为什么这个调用比阻塞调用花费的时间更长。

当调用 getSchedule() 时,订阅 block 不会在查询完成时立即运行。它必须等待 UI 线程,因此如果在另一个方面被阻塞,它将不得不等待。

// start query
database.getSchedule()
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe({
// once ui thread is available, display content
}, {
// ...
})

我的 UI 线程被阻塞的原因是因为我在冷启动时进行测试,所以我的 Fragment 会创建,我的查询会被触发,但它必须等待 UI 其余部分的第一帧在我处理 getSchedule() 结果之前进行渲染。

通过阻塞调用,它已经有了 UI 线程,所以没有等待。

关于android - Room - 后台查询慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50483990/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com