gpt4 book ai didi

android - rx android vs mosby 模式加载数据 recyclerview

转载 作者:塔克拉玛干 更新时间:2023-11-03 01:15:55 28 4
gpt4 key购买 nike

我正在开发一款 Android 应用。我附加的代码正在创建一个回收 View 。我们做的第一件事是创建一个异步任务,它将在 SQLite 数据库上获取数据并将其加载到适配器->recylcerview 中。当后台任务运行时,会向用户显示一个进度对话框。

public class HomeActivity extends AppCompatActivity
{
private RecyclerView recycler;
private RecyclerViewAdapter adapter;
private SwipeRefreshLayout swipeRefresh;
private progressDialog progressDialog;

// ... some code here

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);

// ... some code here


createRecyclerView();
loadRecyclerView();


// ... some code here

}


private void loadRecyclerView()
{
new LoadingBackgroundTask().execute();
}



private void createRecyclerView()
{

Context context = getApplicationContext();

recycler = (RecyclerView) findViewById(R.id.recycle_view_home);
recycler.setHasFixedSize(true);

RecyclerView.LayoutManager lManager = new LinearLayoutManager(context);
recycler.setLayoutManager(lManager);

adapter = new RecyclerViewAdapter();

recycler.setAdapter(adapter);
recycler.setItemAnimator(new DefaultItemAnimator());

}

private class LoadingBackgroundTask extends AsyncTask<Void, Void, List<items>> {

@Override
protected void onPreExecute() {
super.onPreExecute();
progressDialog = ProgressDialog.show(HomeActivity.this, getString(R.string.dialog_load_list),getString(R.string.dialog_please_wait), false, false);

}

@Override
protected List doInBackground(Void... params) {

List<items> lists;
//Data Source Class ( SQLite)
ListDS listDS = new ListDS(getApplicationContext());
list = listDS.getList();

return list;
}

@Override
protected void onPostExecute(List result) {
super.onPostExecute(result);

//it inserts de list on recyclerview performing animation
adapter.animate(result);

progressDialog.dissmiss();
swipeRefresh.setRefreshing(false);
recycler.scrollToPosition(0);
}

}

}

到目前为止,还不错。但是,您可能知道这段代码有一些众所周知的问题;例如,如果我在 asynctask 发挥它的魔力时旋转屏幕,它会使应用程序崩溃。

我已经尝试过谷歌搜索的替代方案,rxandroid

(对不起,如果我打错了,我是凭内存做的)

public class HomeActivity extends AppCompatActivity
{
private Subscriber suscriptor;
private progressDialog progressDialog;

//some code ....

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);

suscriptor = new Subscriber() {
@Override
public void onCompleted() {
progressDialog.dismiss();
Log.d("SUSCRIPTOR","ON COMPLETE");
}

@Override
public void onError(Throwable e) {
Log.d("SUSCRIPTOR","ON ERROR");
}

@Override
public void onNext(Object o) {
adapter.animate((List<items>)o);

}
};


Observable.create(
new Observable.OnSubscribe<List<items>>() {
@Override
public void call(Subscriber<? super List<items>> sub) {
progressDialog = ProgressDialog.show(HomeActivity.this, getString(R.string.dialog_load_list),getString(R.string.dialog_please_wait), false, false);
List<items> lists;
//Data Source Class ( SQLite)
ListDS listDS = new ListDS(getApplicationContext());
list = listDS.getList();

sub.onNext(list);
sub.onCompleted();

}

@Override
protected void finalize() throws Throwable {
super.finalize();
Log.d("OBSERAVBLE","FINALIZED");
}
})
.observeOn(AndroidSchedulers.mainThread())
.subscribeOn(Schedulers.newThread())
.cache()
.subscribe(suscriptor);

}


@Override
public void onDestroy()
{
if(suscriptor!=null)
{
if(!suscriptor.isUnsubscribed())
{
suscriptor.unsubscribe();
}
}

super.onDestroy();
}

}

现在,当我旋转屏幕时,应用程序不再崩溃。然而,observable 一直在后台工作,直到它完成,但是当我取消订阅以避免崩溃时,我没有正确收到结果。此外,即使 observable 像我提到的那样继续工作,进度条也会消失。

在寻找解决方案时,我发现有一种名为“Ted Mosby”的模式似乎可以解决我的问题。虽然它看起来很有希望,但我认为对于一些我认为不值得的东西来说编码太多,rxandroid 可能有一个解决方法。

所以,我的问题是,如何才能在不陷入对我的目的来说太大的架构编码困惑的情况下获得我想要的东西?如果你们解决了这个问题,你能举个例子吗?你认为我错了,我应该实现 TedMosby 模式吗?

最佳答案

Mosby 是一个Mmodel-View-Presenter (MVP) 库。所以你命名为“ted mosby 模式”的模式实际上是 MVP。

但是您还不了解 MVP 是什么。这不是关于保留异步运行任务,甚至认为这可以通过 Mosby 实现。 MVP 是关于关注点分离的。 View 只是显示 UI 元素,Presenter 控制着 View,即 Presenter 告诉 View:现在显示进度对话框,现在隐藏进度对话框等。换句话说,Presenter 控制 View 的状态。 Model 可以是异步任务或 RxJava Observable。然后 Presenter 取回结果并告诉 View 显示它。您的代码被解耦为 3 层模型(也称为业务逻辑)以及 Presenter 和 View。优点是您可以更改 View (即用进度条小部件替换进度对话框)而无需触及任何加载数据的代码(Presenter 和业务逻辑)。此外,通过 MVP,您的代码变得可测试。

所以你应该比较的是:我应该使用 AsyncTask 还是 RxJava 来加载数据。使用 Mosby,您可以在演示器中执行您的 http 请求。完成方向更改后,演示者不会被破坏(因此后台任务不会被取消)。

但是,MVP 并不是万能的解决方案。如果您必须确保正确执行单个 http 调用(即注册社区),您应该考虑使用 android 服务。

关于android - rx android vs mosby 模式加载数据 recyclerview,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35101267/

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