gpt4 book ai didi

kotlin - PageKeyedDataSource loadAfter 连续调用

转载 作者:行者123 更新时间:2023-12-04 15:49:45 25 4
gpt4 key购买 nike

我有一个连续调用loadAfter的PageKeyedDataSource,所有的项目都多次添加到Recyclerview中。从 API 方面来看,一个空 lastEvaluatedKey 意味着给我第一页,这对于为什么它一直调用以获取第一页但 A 有点道理。如果没有更多数据要获取,它不应该停止(又名 params.key == null 吗?和 B.适配器中的 COMPARATOR 不应该不允许多次添加相同的项目吗?我错过了什么?

PageKeyedDataSource.kt

class ReservationsPageKeyedDataSource(private val retryExecutor: Executor) : PageKeyedDataSource<String, Reservation?>() {

private var retry: (() -> Any)? = null

val initialLoad = MutableLiveData<PagingNetworkState>()

fun retryAllFailed() {
val prevRetry = retry
retry = null
prevRetry?.let {
retryExecutor.execute {
it.invoke()
}
}
}

override fun loadInitial(
params: LoadInitialParams<String>,
callback: LoadInitialCallback<String, Reservation?>
) {
val request = Api.reservationsService.getReservations(dateType = RERVATIONS_DATE_TYPE.future, last = null)

initialLoad.postValue(PagingNetworkState.LOADING)

// triggered by a refresh, execute in sync
try {
val response = request.execute()
val originalData = response.body()?.result?.reservations
val data = mutableListOf<Reservation>()
// some data munipulation
retry = null
initialLoad.postValue(PagingNetworkState.LOADED)

callback.onResult(
data.toList(),
null,
response.body()?.result?.lastEvaluatedKey.toString()
)
} catch (ioException: IOException) {
retry = {
loadInitial(params, callback)
}
val error = PagingNetworkState.error(ioException.message ?: "unknown error")
initialLoad.postValue(error)
}
}

override fun loadBefore(
params: LoadParams<String>,
callback: LoadCallback<String, Reservation?>
) {
// no-op
}

override fun loadAfter(
params: LoadParams<String>,
callback: LoadCallback<String, Reservation?>
) {

// I tried adding an if statement here to check if the params.key is null or not but that didn't help

Api.reservationsService.getReservations(dateType = RERVATIONS_DATE_TYPE.future, last = params.key)
.enqueue(object : Callback<ReservationListResponse> {
override fun onFailure(call: Call<ReservationListResponse>, t: Throwable) {
retry = { loadAfter(params, callback) }
}

override fun onResponse(
call: Call<ReservationListResponse>,
response: Response<ReservationListResponse>
) {
if (response.isSuccessful) {
val data = response.body()?.result?.reservations
retry = null
callback.onResult(
data.orEmpty(),
response.body()?.result?.lastEvaluatedKey.toString()
)
} else {
retry = { loadAfter(params, callback) }
}
}
})
}
}

PagedListAdapter 中的比较器:
companion object {
val COMPARATOR = object : DiffUtil.ItemCallback<Reservation>() {
override fun areContentsTheSame(oldItem: Reservation, newItem: Reservation): Boolean =
oldItem == newItem

override fun areItemsTheSame(oldItem: Reservation, newItem: Reservation): Boolean =
oldItem.id == newItem.id
}
}

最佳答案

另一个可能的原因是,如果您在 ScrollView 内部使用 Recycleview,loadAfter 将被无限调用,直到数据完成。
Recycleview 会自动处理滚动,所以不要在 scrollView 中使用它。

关于kotlin - PageKeyedDataSource loadAfter 连续调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58735434/

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