listview优化几种写法(原创)

简介: 这篇文章只是总结下getView里面优化视图的几种写法,就像孔乙己写茴香豆的茴字的几种写法一样,高手勿喷,勿笑,只是拿出来分享,有错误的地方欢迎大家指正,谢谢。      listview       A view that shows items in a vertically scrolling list    。

 这篇文章只是总结下getView里面优化视图的几种写法,就像孔乙己写茴香豆的茴字的几种写法一样,高手勿喷,勿笑,只是拿出来分享,有错误的地方欢迎大家指正,谢谢。     

listview

      A view that shows items in a vertically scrolling list    。一个显示一个垂直的滚动子项的列表视图

     在android开发中,使用listview的地方很多,用它来展现数据,成一个垂直的视图。使用listview是一个标准的适配器模式,用数据--,界面--xml以及适配器--adapter,数据被适配器按照需要的方式展现出来,xml描写了数据如何展现,activity中控制这些活动。

      其中使用自定义的adapter,会要重写getView方法,在getView方法产生给用户item的视图以及数据。

  见图:

  

 

      这里有一个优化的地方,就是重用view,这样减少内存消耗,同时加快item加载速度。

      在getView中优化的地方,大家想必都非常情况,下面我总结了三种优化的写法,请大家指正。

      第一:

     重用了convertView,很大程度上的减少了内存的消耗。通过判断convertView是否为null,是的话就需要产生一个视图出来,然后给这个视图数据,最后将这个视图返回给底层,呈献给用户。

     特点:如果当前的convertView为null,则通过LayoutInflat产生一个view。

View Code
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);
        ContactInfo1 confo =  contacts.get(position);
        if (confo != null) {//to set every item's text
            
            tv_name.setText(confo.getContactName());
            tv_phone.setText(confo.getContact_Phone());
        }
        return convertView;
   
    }

     第二:

     上面的写法会有一个缺点,就是每次在getVIew的时候,都需要重新的findViewById,重新找到控件,然后进行控件的赋值以及事件相应设置。这样其实在做重复的事情,因为的geiview中,其实包含有这些控件,而且这些控件的id还都是一样的,也就是其实只要在view中findViewById一次,后面无需要每次都要findViewById了。

    下面给出第二种写法

     写发的特点,通常有一个内部类class ViewHolder,这个ViewHolder,用来标识view中一些控件,方便进行一些事件相应操作的设置,比如onClick等等,这样可以不用每次都要findViewById了,减少了性能的消耗。同时重用了convertView,很大程度上的减少了内存的消耗。

View Code
 public View getView(int position, View convertView, ViewGroup parent)
    {
        ViewHolder holder ;
        if (convertView == null) {
            convertView = LayoutInflater.from(context).inflate(R.layout.section_list_item1, null);
            holder = new ViewHolder();
            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();
        }
        ContactInfo1 confo =  contacts.get(position);
        Log.i("my", "confo "+confo.getContactName());
        if (confo != null) {//to set every item's text
             
           
            holder.tv_name.setText(confo.getContactName());
            holder.tv_phone.setText(confo.getContact_Phone());
            
        }
        return convertView;
    
    }
    class ViewHolder
    {
        TextView tv_name,tv_phone;
        
    }

    第三:
  个人觉得这个写法是最舒服的,最舒服的意思是看着代码有一种很爽,看的很清晰。

    特点,使用了内部类class ViewHolder、重用了convertView。

    区别第二种写法是,使用了一个临时变量View view = convertView,然后修改view,最后返回view

View Code
 @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 = new ViewHolder();
          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();
      }
      ContactInfo1 confo =  contacts.get(position);
      Log.i("my", "confo "+confo.getContactName());
      if (confo != null) {//to set every item's text
           
         
          holder.tv_name.setText(confo.getContactName());
          holder.tv_phone.setText(confo.getContact_Phone());
          
      }
      return view;
    }
    class ViewHolder
    {
        TextView tv_name,tv_phone;
        
    }

  以上就是集中写法,供新手学习和总结。

源代码如下:LisViewTest.zip

 根据楼下朋友提供的建议,发现还有优化的地方,最新更新如下:    

      

View Code 
 
@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 = new ViewHolder();
          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();
      }
      ContactInfo1 confo =  contacts.get(position);
      Log.i("my", "confo "+confo.getContactName());
      if (confo != null) {//to set every item's text
            
          
          holder.tv_name.setText(confo.getContactName());
          holder.tv_phone.setText(confo.getContact_Phone());
           
      }
      return view;
    }
   <font color="\"#0000ff\""> </font>static class ViewHolder
    {
        TextView tv_name,tv_phone;
         
    }

 注意:static class ViewHolder
     这里设置ViewHolder 为static,也就是静态的,静态类只会在第一次加载时 会耗费比较长时间,但是后面就可以很好帮助加载,同时保证了内存中只有一个ViewHolder,节省了内存的开销。
     非常感谢大家提出建议以及大家的关注!

   

目录
相关文章
|
11天前
|
人工智能 自然语言处理 监控
OpenClaw skills重构量化交易逻辑:部署+AI全自动炒股指南(2026终极版)
2026年,AI Agent领域最震撼的突破来自OpenClaw(原Clawdbot)——这个能自主规划、执行任务的智能体,用50美元启动资金创造了48小时滚雪球至2980美元的奇迹,收益率高达5860%。其核心逻辑堪称教科书级:每10分钟扫描Polymarket近千个预测市场,借助Claude API深度推理,交叉验证NOAA天气数据、体育伤病报告、加密货币链上情绪等多维度信息,捕捉8%以上的定价偏差,再通过凯利准则将单仓位严格控制在总资金6%以内,实现低风险高频套利。
5285 46
|
28天前
|
人工智能 自然语言处理 Shell
🦞 如何在 OpenClaw (Clawdbot/Moltbot) 配置阿里云百炼 API
本教程指导用户在开源AI助手Clawdbot中集成阿里云百炼API,涵盖安装Clawdbot、获取百炼API Key、配置环境变量与模型参数、验证调用等完整流程,支持Qwen3-max thinking (Qwen3-Max-2026-01-23)/Qwen - Plus等主流模型,助力本地化智能自动化。
39471 156
🦞 如何在 OpenClaw (Clawdbot/Moltbot) 配置阿里云百炼 API
|
6天前
|
存储 人工智能 负载均衡
阿里云OpenClaw多Agent实战宝典:从极速部署到AI团队搭建,一个人=一支高效军团
在AI自动化时代,单一Agent的“全能模式”早已无法满足复杂任务需求——记忆臃肿导致响应迟缓、上下文污染引发逻辑冲突、无关信息加载造成Token浪费,这些痛点让OpenClaw的潜力大打折扣。而多Agent架构的出现,彻底改变了这一现状:通过“单Gateway+多分身”模式,让一个Bot在不同场景下切换独立“大脑”,如同组建一支分工明确的AI团队,实现创意、写作、编码、数据分析等任务的高效协同。
1868 25
|
3天前
|
人工智能 JavaScript API
2026年Windows系统本地部署OpenClaw指南:附阿里云简易部署OpenClaw方案,零技术基础也能玩转AI助手
在AI办公自动化全面普及的2026年,OpenClaw(原Clawdbot、Moltbot)凭借“自然语言指令操控、多任务自动化执行、多工具无缝集成”的核心优势,成为个人与轻量办公群体打造专属AI助手的首选。它彻底打破了传统AI“只会对话不会执行”的局限——“手”可读写本地文件、执行代码、操控命令行,“脚”能联网搜索、访问网页并分析内容,“大脑”则可灵活接入通义千问、OpenAI等云端API,或利用本地GPU运行模型,真正实现“聊天框里办大事”。
766 1
|
6天前
|
人工智能 自然语言处理 安全
2026年OpenClaw Skills安装指南:Top20必装清单+阿里云上部署实操(附代码命令)
OpenClaw(原Clawdbot)的强大之处,不仅在于其开源免费的AI执行引擎核心,更在于其庞大的Skills生态——截至2026年2月,官方技能市场ClawHub已收录1700+各类技能插件,覆盖办公自动化、智能交互、生活服务等全场景。但对新手而言,面对海量技能往往无从下手,盲目安装不仅导致功能冗余,还可能引发权限冲突与安全风险。
971 7
|
24天前
|
人工智能 安全 机器人
OpenClaw(原 Clawdbot)钉钉对接保姆级教程 手把手教你打造自己的 AI 助手
OpenClaw(原Clawdbot)是一款开源本地AI助手,支持钉钉、飞书等多平台接入。本教程手把手指导Linux下部署与钉钉机器人对接,涵盖环境配置、模型选择(如Qwen)、权限设置及调试,助你快速打造私有、安全、高权限的专属AI助理。(239字)
9056 24
OpenClaw(原 Clawdbot)钉钉对接保姆级教程 手把手教你打造自己的 AI 助手
|
6天前
|
人工智能 自然语言处理 安全
2026年OpenClaw(Clawdbot)效率翻倍指南:部署+10个必备Skills,解锁AI生产力
很多用户部署OpenClaw(Clawdbot)后都会陷入“看似强大却不好用”的困境,核心原因在于没有搭配合适的Skills(技能插件)。OpenClaw本体就像一台高性能电脑,而Skills如同各类专业软件,只有装上必备技能,才能真正发挥其自动化办公、开发辅助、内容创作等全场景能力。
988 6