1.关于 getCount()这个方法:首先要判断填充的数据是否为null,其次填充数据的size是否为0。
@Override public int getCount() { if (mList != null && mList.size() > 0) { return mList.size(); } return 0; }2.关于getView()这个方法,首先判断convertView是否为空,如果是空的那么我们对他进行重新赋值,并将其存入View的Tag,如果不为空的话,直接从View中根据Tag获取到ViewHolder对象,这样就是可以复用convertView,View的setTag与getTag的API也是第一次接触。
网上比较高端的说法:在Adapter的代码中,在getView方法里首先判断convertView是否为空,若为空则加载相应布局,若不为空则直接使用该布局,这能够很有效的使用Android为listview提供的缓存机制:只加载一屏的布局,之后滑动出来的item使用的是之前已经加载的布局的缓存;
@Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder viewHolder = null; if (convertView == null) { viewHolder = new ViewHolder(); convertView = View.inflate(context, R.layout.rent_assessment_part_info_item, null); viewHolder.checkMonth = (TextView) convertView.findViewById(R.id.tv_checkMonth); convertView.setTag(viewHolder); } else { viewHolder = (ViewHolder) convertView.getTag(); }
return convertView; }3.使用静态内部类定义ViewHolder的 目的则是节省了findViewById的时间。如果不使用ViewHolder,每次getView的时候都需要得到一次子布局,而这也是很耗时并且耗资源的;如果使用了ViewHolder作为子布局的缓存,使用View的setTag方法将缓存与每个item绑定,则也可以省去了findViewById的事件;而将ViewHolder设置为static的目的是指在初始化Adapter时初始化一次这个内部类,否则将会在每次创建Adapter时都要初始化一次,而这是没有必要的。
public static class ViewHolder { TextView checkMonth; }
总的来说,ListView的优化就是将getView里面的耗时操作淡化,将一些耗时操作异步处理,或者将资源准备好,需要的时候只需绑定即可。