[关闭]
@coder-pig 2015-09-20T06:11:51.000000Z 字数 2842 阅读 993

Android基础入门教程——2.4.3 BaseAdapter优化

Android基础入门教程


本节引言:

上一节中我们学习了如何来使用一个ListView以及自定义一个简单的BaseAdapter,我们从代码
中可以看出比较重要的两个方法:getCount()和getView(),界面上有多少列就会调用多少次getView,
这个时候可能看出一些端倪,每次都是新inflate一个View,都要进行这个XML的解析,这样会
很浪费资源,当然,几十列或者几百列的列表并不能体现什么问题,但假如更多或者布局更加复杂?
所以学习ListView的优化很重要,而本节针对的是BaseAdapter的优化,优化的两点有,复用convertView
以及使用ViewHolder重用组件,不用每次都findViewById,我们具体通过代码来体会吧!


1.复用ConvertView:

上面也说了,界面上有多少个Item,那么getView方法就会被调用多少次!
我们来看看上一节我们写的getView()部分的代码:

  1. @Override
  2. public View getView(int position, View convertView, ViewGroup parent) {
  3. convertView = LayoutInflater.from(mContext).inflate(R.layout.item_list_animal,parent,false);
  4. ImageView img_icon = (ImageView) convertView.findViewById(R.id.img_icon);
  5. TextView txt_aName = (TextView) convertView.findViewById(R.id.txt_aName);
  6. TextView txt_aSpeak = (TextView) convertView.findViewById(R.id.txt_aSpeak);
  7. img_icon.setBackgroundResource(mData.get(position).getaIcon());
  8. txt_aName.setText(mData.get(position).getaName());
  9. txt_aSpeak.setText(mData.get(position).getaSpeak());
  10. return convertView;
  11. }

是吧,inflate()每次都要加载一次xml,其实这个convertView是系统提供给我们的可供服用的View
的缓存对象,那就坐下判断咯,修改下,优化后的代码:

  1. @Override
  2. public View getView(int position, View convertView, ViewGroup parent) {
  3. if(convertView == null){
  4. convertView = LayoutInflater.from(mContext).inflate(R.layout.item_list_animal,parent,false);
  5. }
  6. ImageView img_icon = (ImageView) convertView.findViewById(R.id.img_icon);
  7. TextView txt_aName = (TextView) convertView.findViewById(R.id.txt_aName);
  8. TextView txt_aSpeak = (TextView) convertView.findViewById(R.id.txt_aSpeak);
  9. img_icon.setBackgroundResource(mData.get(position).getaIcon());
  10. txt_aName.setText(mData.get(position).getaName());
  11. txt_aSpeak.setText(mData.get(position).getaSpeak());
  12. return convertView;
  13. }

2.ViewHolder重用组件

嘿嘿,getView()会被调用多次,那么findViewById不一样得调用多次,而我们的ListView的Item
一般都是一样的布局,我们可以对这里在优化下,我们可以自己定义一个ViewHolder类来对这一部分
进行性能优化!修改后的代码如下:

  1. @Override
  2. public View getView(int position, View convertView, ViewGroup parent) {
  3. ViewHolder holder = null;
  4. if(convertView == null){
  5. convertView = LayoutInflater.from(mContext).inflate(R.layout.item_list_animal,parent,false);
  6. holder = new ViewHolder();
  7. holder.img_icon = (ImageView) convertView.findViewById(R.id.img_icon);
  8. holder.txt_aName = (TextView) convertView.findViewById(R.id.txt_aName);
  9. holder.txt_aSpeak = (TextView) convertView.findViewById(R.id.txt_aSpeak);
  10. convertView.setTag(holder); //将Holder存储到convertView中
  11. }else{
  12. holder = (ViewHolder) convertView.getTag();
  13. }
  14. holder.img_icon.setBackgroundResource(mData.get(position).getaIcon());
  15. holder.txt_aName.setText(mData.get(position).getaName());
  16. holder.txt_aSpeak.setText(mData.get(position).getaSpeak());
  17. return convertView;
  18. }
  19. static class ViewHolder{
  20. ImageView img_icon;
  21. TextView txt_aName;
  22. TextView txt_aSpeak;
  23. }

没错就是这么简单,你以后BaseAdapter照着这个模板写就对了,哈哈,另外这个修饰ViewHolder的
static你可以看情况改成其他的,如果条目较少的话,可以使用static,如果条目多的花,还是别
定义成静态的~


本节小结:

好的,关于BaseAdapter的优化大概就上述的两种,非常简单,复用ConvertView以及自定义ViewHolder
减少findViewById()的调用~如果你有其他关于BaseAdapter优化的建议欢迎提出,谢谢~

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注