Java 为什么分页库在多次调用后停止加载数据?
我实现了一个分页库,但它并没有正常工作。我从github请求数据,并对存储库列表进行分页。代码运行良好,但在对搜索查询进行多次更改后,它停止加载数据。在调试中,数据总是加载良好。我想问题是异步的,但我不知道应该在哪里查找。 我的代码: 报告数据源Java 为什么分页库在多次调用后停止加载数据?,java,android,paging,Java,Android,Paging,我实现了一个分页库,但它并没有正常工作。我从github请求数据,并对存储库列表进行分页。代码运行良好,但在对搜索查询进行多次更改后,它停止加载数据。在调试中,数据总是加载良好。我想问题是异步的,但我不知道应该在哪里查找。 我的代码: 报告数据源 public class RepoDataSource extends PageKeyedDataSource<Integer, Repo> { @Override public void loadInitial(@NonNull
public class RepoDataSource extends PageKeyedDataSource<Integer, Repo> {
@Override
public void loadInitial(@NonNull LoadInitialParams<Integer> params, @NonNull LoadInitialCallback<Integer, Repo> callback) {
Timber.d("Initial RepoDataSource");
try {
Response<RepoSearchResponse> response = githubService.searchRepos(query, firstNumberPage).execute();
RepoSearchResponse repoSearchResponse = response.body();
if (repoSearchResponse != null) {
List<Repo> items = repoSearchResponse.getItems();
callback.onResult(items, 1, 2);
}
} catch (IOException e) {
Timber.i(e);
}
}
@Override
public void loadBefore(@NonNull LoadParams<Integer> params, @NonNull LoadCallback<Integer, Repo> callback) {
}
@Override
public void loadAfter(@NonNull LoadParams<Integer> params, @NonNull LoadCallback<Integer, Repo> callback) {
Timber.d("Fetching next page: %s", params.key);
try {
Response<RepoSearchResponse> response = githubService.searchRepos(query, params.key).execute();
if (response.isSuccessful()) {
RepoSearchResponse repoSearchResponse = response.body();
if (repoSearchResponse != null) {
List<Repo> items = repoSearchResponse.getItems();
callback.onResult(items, params.key + 1);
}
}
} catch (IOException e) {
Timber.i(e);
}
}
}
视图模型
public final class MyViewModel {
...
public MutableLiveData<String> searchQuery = new MutableLiveData<>();
...
public LiveData<PagedList<Repo>> getRepos() {
return Transformations.switchMap(searchQuery, query -> {
RepoDataSourceFactory factory = repository.getRepoPagedFactory(query);
return new LivePagedListBuilder<>(factory, pagedListConfig).build();
});
}
...
public SearchView.OnQueryTextListener listener = new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String query) {
if (query != null && !query.trim().equals("")) {
searchQuery.postValue(query);
}
return true;
}
@Override
public boolean onQueryTextChange(String newText) {
return true;
}
};
...
}
你的代码没有问题。我在一个GitHub项目上,遇到了同样的问题,直到我意识到GitHub对未经身份验证的请求有每分钟10个请求的速率限制。但是如果它是经过身份验证的,那么每分钟最多可以发出30个请求 我假设您也会发送搜索查询中每次更改的请求,就像我做的那样,输入/更改5个字符等于5个请求。所以真正的原因是来自GitHub的请求率非常有限,而不是您的代码
检查此项:您的代码没有问题。我在一个GitHub项目上,遇到了同样的问题,直到我意识到GitHub对未经身份验证的请求有每分钟10个请求的速率限制。但是如果它是经过身份验证的,那么每分钟最多可以发出30个请求 我假设您也会发送搜索查询中每次更改的请求,就像我做的那样,输入/更改5个字符等于5个请求。所以真正的原因是来自GitHub的请求率非常有限,而不是您的代码 看看这个:
public class RepoDataSourceFactory extends DataSource.Factory<Integer, Repo> {
private GithubService githubService;
private String query;
public RepoDataSourceFactory(GithubService githubService, String query) {
this.githubService = githubService;
this.query = query;
}
@NonNull
@Override
public DataSource<Integer, Repo> create() {
return new RepoDataSource(githubService, query);
}
}
public class RepoRepository {
...
...
public RepoDataSourceFactory getRepoPagedFactory(String query) {
return new RepoDataSourceFactory(githubService, query);
}
}
public final class MyViewModel {
...
public MutableLiveData<String> searchQuery = new MutableLiveData<>();
...
public LiveData<PagedList<Repo>> getRepos() {
return Transformations.switchMap(searchQuery, query -> {
RepoDataSourceFactory factory = repository.getRepoPagedFactory(query);
return new LivePagedListBuilder<>(factory, pagedListConfig).build();
});
}
...
public SearchView.OnQueryTextListener listener = new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String query) {
if (query != null && !query.trim().equals("")) {
searchQuery.postValue(query);
}
return true;
}
@Override
public boolean onQueryTextChange(String newText) {
return true;
}
};
...
}
viewModel.getRepos().observe(this, adapter::submitList);