android设计中基本都是使用adapter来进行数据和控件绑定。
在我的使用中发现过adapter中存在一个地方很容易让人忽视,从而导致adapter在改变数据以后,刷新不了。
我们来看看这个问题
public class ContantsListAdpater extends BaseAdapter {
private LayoutInflater mInflater;
private ArrayList<Contants> mData;
private Context mContext;
public ContantsListAdpater(Context context,ArrayList<Contants> mData) {
mContext = context;
mInflater = LayoutInflater.from(context);
this.mData = mData;
}
public interface OnItemCheckedListener {
void onItemChecked(String mac, boolean isChecked, TextView status);
}
@Override
public int getCount() {
return mData == null ? 0 : mData.size();
}
@Override
public Contants getItem(int position) {
return mData.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
final ViewHolder holder;
if (convertView == null) {
convertView = mInflater.inflate(R.layout.adapter_share_list_item, parent,
false);
holder = new ViewHolder();
holder.icon = (ImageView) convertView.findViewById(R.id.icon);
holder.name = (TextView) convertView.findViewById(R.id.name);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
holder.name.setText(mData.get(position).getName());
return convertView;
}
protected static class ViewHolder {
ImageView icon;
TextView name;
}
}
这是最简单的adapter例子。
我们经常会对mData这个变量生成get和set方法。
然后我们在获取到了新的列表时,重新set mData然后刷新适配器。 然而现实是残酷的adapter并没有刷新。
很多同学的解决办法就是重新new 一遍adapter然后重新setadapter。问题解决。
但是为甚么这里会需要我们重新new一次呢。
简单来说adapter在监听数据源时在第一次设置的mData的内存地址,而我们重新set mData的时候获取到的新list是一个不同的地址。然后刷新适配器的时候 适配器并没有去查找我们新的地址,而是老地址上。适配器发现老地址的数据源并没有被改变。
如果你不想每次都重新new 一次适配器,只需要将传入的list.clear(); 然后list.addAll(newList);