android listview优化几种写法详细介绍

本文总结了ListView适配器模式下优化视图加载的三种方法:重用convertView减少内存消耗,避免重复findViewById操作,以及使用内部类ViewHolder简化代码。通过实例代码展示每种方法的特点与优势。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这篇文章只是总结下getView里面优化视图的几种写法,就像孔乙己写茴香豆的茴字的几种写法一样,高手勿喷,勿笑,只是拿出来分享,有错误的地方欢迎大家指正,谢谢。
listview
A view that shows item sina vertically scrolling list。
一个显示一个垂直的滚动子项的列表视图在android开发中,使用listview的地方很多,用它来展现数据,成一个垂直的视图。使用listview是一个标准的适配器模式,用数据--,界面--xml以及适配器--adapter,数据被适配器按照需要的方式展现出来,xml描写了数据如何展现,activity中控制这些活动。
其中使用自定义的adapter,会要重写getView方法,在getView方法产生给用户item的视图以及数据。
见图:
 
这里有一个优化的地方,就是重用view,这样减少内存消耗,同时加快item加载速度。
在getView中优化的地方,大家想必都非常情况,下面我总结了三种优化的写法,请大家指正。
第一
重用了convertView,很大程度上的减少了内存的消耗。通过判断convertView是否为null,是的话就需要产生一个视图出来,然后给这个视图数据,最后将这个视图返回给底层,呈献给用户。
特点:如果当前的convertView为null,则通过LayoutInflat产生一个view。
复制代码 代码如下:

ViewCode
public View getView(int position,View convertView,ViewGroup parent)

    if(convertView==null) 
    { 
        convertView=LayoutInflater.from(context).inflate(R.layout.section_list_item1,null); 
    } 
    TextView tv_name=(TextView)convertView.findViewById(R.id.contact_contactinfoitem_tv_name); 
    TextView tv_phone=(TextView)convertView.findViewById(R.id.contact_contactinfoitem_tv_phoneNum); 
    ContactInfo confo=contacts.get(position); 
    if(confo!=null) {//toseteveryitem'stext 
        tv_name.setText(confo.getContactName()); 
        tv_phone.setText(confo.getContact_Phone()); 
    } 
    return convertView;
}

第二
上面的写法会有一个缺点,就是每次在getVIew的时候,都需要重新的findViewById,重新找到控件,然后进行控件的赋值以及事件相应设置。这样其实在做重复的事情,因为的geiview中,其实包含有这些控件,而且这些控件的id还都是一样的,也就是其实只要在view中findViewById一次,后面无需要每次都要findViewById了。
下面给出第二种写法
写发的特点,通常有一个内部类classViewHolder,这个ViewHolder,用来标识view中一些控件,方便进行一些事件相应操作的设置,比如onClick等等,这样可以不用每次都要findViewById了,减少了性能的消耗。同时重用了convertView,很大程度上的减少了内存的消耗。
复制代码 代码如下:

ViewCode
public View getView(int position,View convertView,ViewGroup parent)

    ViewHolderholder; 
    if(convertView==null) { 
        convertView=LayoutInflater.from(context).inflate(R.layout.section_list_item1,null); 
        holder=newViewHolder(); 
        holder.tv_name=(TextView)convertView.findViewById(R.id.contact_contactinfoitem_tv_name); 
        holder.tv_phone=(TextView)convertView.findViewById(R.id.contact_contactinfoitem_tv_phoneNum); 
        convertView.setTag(holder); 
    } 
    else 
    { 
        holder=(ViewHolder)convertView.getTag(); 
    } 
    ContactInfo confo=contacts.get(position); 
    Log.i("my","confo"+confo.getContactName()); 
    if(confo!=null) {//toseteveryitem'stext 

        holder.tv_name.setText(confo.getContactName()); 
        holder.tv_phone.setText(confo.getContact_Phone()); 
    } 
    return convertView;
}
class ViewHolder

    TextViewt v_name, tv_phone;
}

第三
 个人觉得这个写法是最舒服的,最舒服的意思是看着代码有一种很爽,看的很清晰。
特点,使用了内部类classViewHolder、重用了convertView。
区别第二种写法是,使用了一个临时变量Viewview=convertView,然后修改view,最后返回view
复制代码 代码如下:

ViewCode
@Override
public View getView(int position,View convertView,ViewGroup parent)

    View view=convertView; 
    ViewHolder holder; 
    if(view==null) { 
        view=LayoutInflater.from(context).inflate(R.layout.section_list_item1,null); 
        holder=newViewHolder(); 
        holder.tv_name=(TextView)view.findViewById(R.id.contact_contactinfoitem_tv_name); 
        holder.tv_phone=(TextView)view.findViewById(R.id.contact_contactinfoitem_tv_phoneNum); 
        view.setTag(holder); 
    } 
    else 
    { 
        holder=(ViewHolder)view.getTag(); 
    } 
    ContactInfo confo=contacts.get(position); 
    Log.i("my","confo"+confo.getContactName()); 
    if(confo!=null) {//toseteveryitem'stext 

        holder.tv_name.setText(confo.getContactName()); 
        holder.tv_phone.setText(confo.getContact_Phone()); 
    } 
    return view;
}
static class ViewHolder

    TextView tv_name, tv_phone;
}

注意:static classViewHolder
这里设置ViewHolder为static,也就是静态的,静态类只会在第一次加载时会耗费比较长时间,但是后面就可以很好帮助加载,同时保证了内存中只有一个ViewHolder,节省了内存的开销。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值