问题描述
总结我的问题:
当我单击按钮时,将调用两种方法。第一种方法显示进度条,清除列表,然后使用notifyDataSetChanged()
public void methodone(){
mProgressBar.setVisibility(View.VISIBLE);
mList.clear;
mAdapter.notifyDataSetChanged();
}
第二种方法使用改造来进行查询,在回调方法中,我隐藏进度条,添加到列表中并调用notifyDataSetChanged();
public void methodTwo(){
RetrofitInterfaces.SearchForPosts service = RetrofitClientInstance.getRetrofitInstance()
.create(RetrofitInterfaces.SearchForPosts.class);
Call<Feed> call = service.listRepos(url);
call.enqueue(new Callback<Feed>() {
@Override
public void onResponse(@NonNull Call<Feed> call,@NonNull Response<Feed> response) {
try{
mProgressBar.setVisibility(View.INVISIBLE);
mList.addAll(response.body().getData());
mAdapter.notifyDataSetChanged();
} catch(Exception e){
Log.e(TAG,"Error: " + e);
}
}
@Override
public void onFailure(@NonNull Call<Feed> call,@NonNull Throwable t) {
Log.e(TAG,"onFailure: " + t);
}
});
}
}
methodone();
methodTwo();
第二个带有改进调用有时的方法返回IndexOutOfBounds异常,因为在我对mList进行编辑时,methodone()调用了mList.clear()
和mAdapter.notifyDataSetChanged();
。
我的问题是如何使两者原子发生,以免彼此干扰? (我希望methodone()甚至在methodTwo中发生查询之前就做所有事情)
解决方法
您可以使用AsyncTask,该方法将在methodOne()完成执行后执行methodTwo()
private class MethodsTask extends AsyncTask<Void,Void,Void> {
@Override
protected Void doInBackground(Void... voids) {
methodOne();
return null;
}
@Override
protected void onPostExecute(Void aVoid) {
super.onPostExecute(aVoid);
methodTwo();
}
}
所以不要调用这两个方法
methodOne();
methodTwo();
使用此
MethodsTask task = new MethodsTask();
task.execute();