listview加载性能优化之view的复用
【摘要】
在android开发中Listview是一个很重要的组件,它以列表的形式根据数据的长自适应展示具体内容,用户可以自由的定义listview每一列的布局,但当listview有大量的数据需要加载的时候,会占据大量内存,影响性能,这时候就需要按需填充并重新使用view来减少对象的创建。
一般我们都会给listview set一个adapt...
在android开发中Listview是一个很重要的组件,它以列表的形式根据数据的长自适应展示具体内容,用户可以自由的定义listview每一列的布局,但当listview有大量的数据需要加载的时候,会占据大量内存,影响性能,这时候就需要按需填充并重新使用view来减少对象的创建。
一般我们都会给listview set一个adapter ,然后adapter里面初始化的方法就是 getview(),这个方法 简单说是这个意思,就是 你的listview有多少行,或者说count值是多少,他就会走多少次getview().所以 优化listview的加载速度就要让convertView匹配列表类型,并最大程度上的重新使用convertView。
getview的加载方法一般有以下三种种方式:
最慢的加载方式是每一次都重新定义一个View载入布局,再加载数据
-
public View getView(int position, View convertView, ViewGroup parent) {
-
View item = mInflater.inflate(R.layout.list_item_icon_text, null);
-
((TextView) item.findViewById(R.id.text)).setText(DATA[position]);
-
((ImageView) item.findViewById(R.id.icon)).setImageBitmap(
-
(position & 1) == 1 ? mIcon1 : mIcon2);
-
return item;
-
}
正确的加载方式是当convertView不为空的时候直接重新使用convertView从而减少了很多不必要的View的创建,然后加载数据
-
public View getView(int position, View convertView, ViewGroup parent) {
-
if (convertView == null) {
-
convertView = mInflater.inflate(R.layout.item, parent, false);
-
}
-
((TextView) convertView.findViewById(R.id.text)).setText(DATA[position]);
-
((ImageView) convertView.findViewById(R.id.icon)).setImageBitmap(
-
(position & 1) == 1 ? mIcon1 : mIcon2);
-
return convertView;
-
}
最快的方式是定义一个ViewHolder,将convetView的tag设置为ViewHolder,不为空时重新使用即可
-
public class ViewHolder {
-
TextView txt;
-
ImageView icon;
-
}
-
-
public View getView(int position, View convertView, ViewGroup parent) {
-
ViewHolder holder;
-
-
if (convertView == null) {
-
convertView = mInflater.inflate(R.layout.list_item_icon_text,
-
parent, false);
-
holder = new ViewHolder();
-
holder.txt= (TextView) convertView.findViewById(R.id.text);
-
holder.icon = (ImageView) convertView.findViewById(R.id.icon);
-
convertView.setTag(holder);
-
} else {
-
holder = (ViewHolder) convertView.getTag();
-
}
-
holder.text.setText(DATA[position]);
-
holder.icon.setImageBitmap((position & 1) == 1 ? mIcon1 : mIcon2);
-
return convertView;
-
}
文章来源: wukong.blog.csdn.net,作者:再见孙悟空_,版权归原作者所有,如需转载,请联系作者。
原文链接:wukong.blog.csdn.net/article/details/44653203
【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
cloudbbs@huaweicloud.com
- 点赞
- 收藏
- 关注作者
评论(0)