RecycleView动态更新数据失败,定位错误分三步

本文介绍了在使用RecycleView显示数据时,动态更新数据不生效的常见问题及其解决步骤。首先检查数据源是否正确,避免使用中间变量的.addAll()导致的数据源地址问题。其次,确保调用了RecycleView的notifyDataSetChanged()方法来通知更新。最后,如果在非主线程更新数据,需通过如runOnUiThread、Handler、AsyncTask或EventBus等方式回调到主线程进行刷新。通过这三个步骤,可以有效定位并解决RecycleView更新问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天记录一下,项目中使用recycleView来显示数据,动态更新,写了一大圈才发现问题出在比较简单的地方,这里也给大家提个醒,遇到RecycleView动态更新数据不显示的问题分三步走:


第一步:

progressDevFragment.setVisibility(View.INVISIBLE);
RecyclerView recyclerView = view.findViewById(R.id.recycler_view);
GridLayoutManager layoutManager = new GridLayoutManager(view.getContext(), 1);
recyclerView.setLayoutManager(layoutManager);
if (comStaList.size() == presenter.getDeviceLength() && rtAiList.size() == presenter.getRtaiLength()) {
    adapter = new MainAdapter(ghList, comStaList, rtAiList, deviceList);
    recyclerView.setAdapter(adapter);
} else {
    comStaList.clear();
    rtAiList.clear();
    comStaList.addAll(presenter.getComstaListData());
    rtAiList.addAll(presenter.getRtaiListData());
    initAdapter();
}

请忽略没用的代码,关键是你是否使用中间变量List<T>的 .addAll()方法,这里涉及到数据源地址得问题,如果我直接使用

MainAdapter adapter = new MainAdapter(ghList, comStaList, presenter.getComstaListData, deviceList);

后台数据在变化,本地sqlite读取也正常,页面数据就是没法发刷新的。


第二步:

更新数据集后是否使用了

adapter.notifyDataSetChanged();
这个方法的作用就是,监测数据源是否发生变化的。

第三步:

adapter.notifyDataSetChanged();

的使用位置,这个时候问题,如果你是单独开了线程去刷新了数据,那么在刷新后一定要通知UI线程,执行上述方法,办法有几种:

1. runOnUiThread(Runnable action)

注意:context 对象要是 主线程中的MainActivity,这样强转才可以。

runOnUiThread(new Runnable() {
            @Override
            public void run() {
                //此时已在主线程中,更新UI
            }
        });

2. Handler机制

3. AsyncTask

4. EventBus

@Subscribe(threadMode = ThreadMode.MAIN)
    public void Event(MessageEvent messageEvent) {
        if (messageEvent.getMessage().equals("refresh")){
            adapter.notifyDataSetChanged();
        }
    }

    private void refreshData(){
        if (timer == null) {
            timer = new Timer();
        }
        if (task == null) {
            task = new TimerTask() {
                @Override
                public void run() {
                    try {
                        initData();
                        MessageEvent messageEventRefresh = new MessageEvent("refresh");
                        EventBus.getDefault().post(messageEventRefresh);
                    } catch (Exception e) {
                        e.printStackTrace();
                    }
                }
            };
        }
        timer.schedule(task, 0, 15*1000);
    }

我项目中用到了EventBus,就用了这种方法,解决了问题,回过头来想想,是有点儿懵了,早该想到的,哈哈!

还是希望大家能快速定位问题解决问题!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值