内容简介:public class ListAdapter extends BaseAdapter{private Context context;private List<ArrayList> list;
学过Android开发的人都知道,ListView控件在开发中经常遇到,并且ListView通常结合Adapter适配器来进行数据显示和数据更新操作。姑且假设数据存储在名为dataList的成员变量中。数据操作无非是增加数据、删除数据这两种主要的操作,而当数据有所变化时,为了及时向用户提供更新后的数据,我们知道需要在数据更新后调用适配器的notifyDataSetChanged()方法,来显示更新后的数据。殊不知,该方法并非百试不爽,在此我们便来讨论下具体的原因,其实本质是关注内存的分配情况。 先来看几段代码。 代码段1(某Activity中):
private List<Map<String,String>> dataList; private ListView listView; private ListAdapter adapter; listView = findViewById(R.id.mancard); adapter = new ListAdapter(this, dataList); listView.setAdapter(adapter);
上述代码是把Adapter适配器和ListView控件进行绑定。 代码段2(ListAdapter中的部分代码):
public class ListAdapter extends BaseAdapter{
private Context context;
private List<ArrayList> list;
ListAdapter(Context context, List list){ this.context = context; this.list = list; } @Override public Object getItem(int position) { return list.get(position); } 上述代码是通过上下文环境和数据列表来构造适配器,并且重写其getItem()方法。在此需要明白的是list成员变量是适配器中的私有变量,getItem()方法是当数据显示在ListView时会回调的方法,或者说当显示数据或数据发生改变重写加载数据时会回调这个方法(当然还会调用getView()方法,此时不再赘述)。 代码段3~6模拟数据改变: 代码段3:
dataList.remove(1);
adapter.notifyDataSetChanged();
代码段4:
Map vivian = new HashMap();
vivian.put("sex", "girl");
vivian.put("nick", "vivian");
vivian.put("content", "阳光魅力大方无极限");
dataList.add(vivian);
adapter.notifyDataSetChanged();
代码段5:
dataList = getData();
adapter.notifyDataSetChanged();
private List getData(){ List data = new ArrayList(); Map vivian = new HashMap(); vivian.put("sex", "girl"); vivian.put("nick", "vivian"); vivian.put("content", "阳光魅力大方无极限"); data.add(vivian); Map Mryang = new HashMap(); Mryang.put("sex", "boy"); Mryang.put("nick", "杨阳洋"); Mryang.put("content", "成熟稳重高富帅"); data.add(Mryang); return data;
}
代码段6:
dataList.clear();
dataList.addAll(getData());
adapter.notifyDataSetChanged();
getData()方法同代码段5(略)
以上几种情况模拟了常用的更新数据的方法,在这几种情况种代码段5不能实现数据的更新操作,代码段3、4、6可以实现数据更新操作。为什么代码段3、4、6可以更新,原因大家都明白,是因为数据发生了变化,因此当调用adapter.notifyDataSetChanged()方法时就会把更新后的数据显示出来。
代码段5的数据也发生了变化,为什么不能实现数据更新呢?
当构造Adapter适配器,数据列表dataList传递过去时,是把dataList指向的地址副本作为参数传递给了adapter中的list成员变量了,因此dataList指向的内存区域和adapter中list指向的内存区域是同一块内存区域,代码段3和代码段4对数据的添加、删除操作是在当前区域内进行的,dataList中数据的变化直接影响了adapter中list的数据的变化,因此adapter中的list能够敏感的发现数据发生变化。
代码段3、4简易模型 代码段5中,对dataList的内存指向做了修改,但是该指向并没有通知到adapter中的list,也就是说list指向没有发生变化,还是指向原来修改前的内存区域,因此dataList的改变并不能引起list的改变,本质上来说list没有发现数据有变化,所以当调用adapter.notifyDataSetChanged()方法时,数据没有更新。而在代码段6中,首先移除dataList中的数据,那么adapter中的list自然能够及时发现数据发生了变化,从而重新从dataList中得到改变后的数据信息,因此当调用adapter.notifyDataSetChanged()方法时能够发生数据的更新。
代码段5简易模型
代码段6简易模型 因此当我们想要更换ListView中的所有数据时,应该采用代码段6的方式,先将数据移除,再重新添加数据或更换新的内存区域指向。
以上所述就是小编给大家介绍的《Android中适配器的notifyDataSetChanged()为何有时不刷新》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
C算法(第二卷:图算法)(第3版)
塞德威克(Sedgewick Robert) / 周良忠 / 第1版 (2004年1月1日) / 2004-4 / 38.0
《C算法(第2卷)(图算法)(第3版)(中文版)》所讨论的图算法,都是实际中解决图问题的最重要的已知方法。《C算法(第2卷)(图算法)(第3版)(中文版)》的主要宗旨是让越来越多需要了解这些算法的人的能够掌握这些方法及基本原理。书中根据基本原理从基本住处开始循序渐进地讲解,然后再介绍一些经典方法,最后介绍仍在进行研究和发展的现代技术。精心挑选的实例、详尽的图示以及完整的实现代码与正文中的算法和应用......一起来看看 《C算法(第二卷:图算法)(第3版)》 这本书的介绍吧!