0. 第0层: 不优化:
每次执行getView(), 都会执行: converterView = View.inflate(R.layout.xxx);
问题: 效率太低, 在快速滑动时会有卡顿, 在数据很多时甚至会内存溢出
if(converterView==null) {
converterView = View.inflate(R.layout.xxx); //n+1
}
问题: 每次执行getView()都需要执行converterView.findViewById()得到子View ImageView
2. 第二层: 使用ViewHolder, 减少findViewById()的次数
Viewholder holder = null;
if(converterView==null) {
converterView = View.inflate(R.layout.xxx);
holder = new ViewHolder();
holder.imageView = (ImageView)converterView.findViewById(xxx);
holder.textView = (TextView)converterView.findViewById(yyy);
converterView.setTag(holder);
} else {
holder = (Viewholder )converterView.getTag();
}
Person p = data.get(position);
holder.imageView.setimage(p.getIcon())
holder.textView.setText(p.getName())
static class ViewHolder {
ImageView imageView;
TextView textView;
}
//json: [{}, {}]
问题1: 对于联网获取列表数据, 如果数据量太大(比如超过100000条甚至更多), 一次获取出来显示, 太慢太耗流量: 第四层优化
问题2: 对于联网获取列表数据, 如果包含图片数据, 每次都请求获取显示, 太慢太耗流量: 第三层优化
3. 第三层优化: 图片三级缓存处理
可以参见
图片三级缓存机制
4. 第四层: 对数据列表进行分页加载显示
1). 通过Scroll监听listView.setonScrollListener(scrollListener), 当到达底部时加载下一页列表数据并显示
2). 使用第三方开源框架: Android-PullToRefresh或其它
5.监听listview的滑动状态
1)如果是滑动状态的话,可以不加载和显示图片及数据,这样可以避免消耗流量和节约内存