转载请注明出处:http://blog.csdn.net/l1028386804/article/details/47209253

作为client。其最基本的任务就是最直观的和用户交互。从server拿数据,解析过后显示数据。依据用户操作依照一定的协议传回数据,达到用户想要的结果。这是我自己的理解,所以我们的程序。必须给用户一个良好的体验。

listView能够说是安卓开发中非常重要的一个控件。我所做的项目中,差点儿每一个页面都会有listView。Adapter是listView和数据源间的中间人。

当每条数据进入可见区域时,adapter的getview()会被调用,返回代表详细数据的视图。触摸滚动时,频繁调用。支持成百上千条数据。然而listView同一时候也非常复杂。想要做好优化也不easy,以下是我自己整理的listView的优化方式

1、最简单的方法。最慢且最不有用

public View getView(int pos, View convertView, ViewGroup parent){
View item = mInflater.inflate(R.layout.list_item, null);
((TextView) item.findViewById(R.id.text)). setText(DATA[pos]);
((ImageView) item.findViewButId(R.id.icon)).
setImageBitmap((pos & 1) == 1 ? mIcon1 : mIcon2);
return item;
}

每条数据我们都会去解析布局。相当于每次都去new一个对象,写第一个listView的时候我也是这样写的,功能自然能实现,可是实际上效率非常低我们

2、能够利用convertView回收视图,效率能提高200%

 public View getView(int pos, View convertView, ViewGroup parent){
if (convertView == null) {
convertView = mInflater.inflate( R.layout.list_item, null);
}
//这个地方相当于做了一个缓存机制。仅仅有convertVIew为空的时候我们才去解析布局,由于解析布局实际上是非常麻烦。非常耗时的。我们仅仅解析一次布局,其它的我们用同一个缓存的布局
((TextView) convertView.findViewById(R.id.text)).
setText(DATA[pos]);
((ImageView) convertView.findViewButId(R.id.icon)).
setImageBitmap((pos & 1) == 1 ? mIcon1 : mIcon2);
return convertView;
}

3、利用viewholder模式。效率在提高50%

static class ViewHolder {
TextView text;
ImageView icon;
}
public View getView(int pos, View convertView, ViewGroup parent){
ViewHolder holder;
if (convertView == null) {
convertView = mInflater.inflate(R.layout.list_item, null);
holder = new ViewHolder();
holder.text = (TextView) convertView.findViewById(R.id.text));
holder.icon = (ImageView) convertView.findViewButId(R.id.icon));
convertView.setTag(holder);
}else{
holder = (ViewHolder) convertView.getTag();
}
holder.text.setText(DATA[pos]);
holder.icon.setImageBitmap((pos & 1) == 1 ? mIcon1 : mIcon2);
return convertView;
}

以上3点是listView中经常使用的。当然也是最主要的优化方式。假设没有什么特殊要求,对于android来说这3种优化是必须存在的。还有其它的一些优化方法:

4、背景和图像

视图背景图像总会填充整个视图区域

    1)图像尺寸不合适会导致自己主动缩放

    2)避免实时缩放

    3)最好预先缩放到视图大小

 originalImage = Bitmap.createScaledBitmap(
originalImage, // 缩放图像
view.getWidth(), // 视图宽度
view.getHeight(), // 视图高度
true); // 线性过滤器

默认情况下, 窗体有一个不透明的背景

    有时能够不须要

    最高层的视图是不透明的      layout_width  = fill_parent

    最高层的视图覆盖整个窗体    layout_height = fill_parent

    更新看不见的背景是浪费时间

5、删除窗体背景:

1)改动编码

 public void onCreate(Bundle icicle){
super.onCreate(icicle);
setContentView(R.layout.mainview);
// 删除窗体背景
getWindow().setBackgroundDrawable(null);
...

6、改动xml

首先确定你的res/values/styles.xml有

parent="android:Theme">

然后编辑androidmainfest.xml

 android:theme="@style/NoBackgroundTheme">
...

7、更新请求

当屏幕须要更新时,调用invalidate()方法,简单方便,可是更新了整个视图。代价太高。  

    最好先找到无效区域。然后调用

invalidate(Rect dirty);
invalidate(int left, int top, int right, int bottom);

8、视图和布局

假设一个窗体包括非常多视图,启动太慢,绘制时间长,用户界面反应速度非常慢

解决方法:

1)使用textview的复合drawable降低层次

android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/hello"
android:drawableLeft="@drawable/icon"/>

2)使用viewstuf延迟展开视图

在xml文件里定义viewstuf

android:inflatedId="@+id/panel_import"
android:layout="@layout/progress_overlay"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_gravity="bottom"/>

在须要展开视图时

findViewById(R.id.stub_import).setVisibility(View.VISIBLE);
// 或者
View importPanel = ((ViewStub)
findViewById(R.id.stub_import)).inflate();

9、使用合并中间视图

默认情况下。布局文件的根作为一个节点。增加到父视图中,假设使用merge能够避免根节点

"http://schemas.android.com/apk/res/android">

10、降低android的容器布局嵌套

android的布局嵌套事实上在解析的时候也是非常花时间的,所以,我们在能实现功能的基础上尽量避免非常多层的嵌套。

写布局的时候养成习惯就跟我们写java代码一样看到反复代码就尽量想办法去优化一样。

11、使用自己定义视图

 class CustomView extends View {

	@Override
protected void onDraw(Canvas canvas) {
// 增加你的画图编码
} @Override
protected void onMeasure(int widthMeasureSpec,
int heightMeasureSpec) {
// 计算视图的尺寸
setMeasuredDimension(widthSpecSize, heightSpecSize); } }

12、内存分配:尽量避免在性能敏感的代码其中创建java对象

測量 onmeasure()
布局onlayout()
画图 ondraw() dispatchdraw()
事件处理 ontouchevent() dispatchtouchevent()
adapter: getview() bindview()

13、管理好对象:

1)适用软引用:内存缓存的最佳选择

2)适用弱引用:避免内存泄露

14、内存缓存:

private final HashMap> mCache;
public void put(String key, T value) {
mCache.put(key, new SoftReference(value));
}
public T get(String key, ValueBuilder builder) {
T value = null;
SoftReferece reference = mCache.get(key);
if (reference != null) {
value = reference.get();
}
return value;
}

Android之——ListView优化的更多相关文章

  1. Android之ListView优化

    关于ListView几个方面的优化: ListView的大小设定固定值; 复用convertView, 使用ViewHolder提高在容器中查找组件的效率; 使用分页加载; 快速滚动时, item不显 ...

  2. 【Android】ListView 优化

    重用 ListView Item ListView创建时其会创建屏幕可容纳数量的 Item.ListView 滚动时,刚消失的 item 会被保存到回收池中.新出现的 item 从回收池中获取避免反复 ...

  3. 【Android】listview优化

    http://www.cnblogs.com/over140/archive/2011/03/23/1991100.html http://blog.sina.com.cn/s/blog_5fc933 ...

  4. Android之ListView性能优化——一行代码绑定数据——万能适配器

    如下图,加入现在有一个这样的需求图,你会怎么做?作为一个初学者,之前我都是直接用SimpleAdapter结合一个Item的布局来实现的,感觉这样实现起来很方便(基本上一行代码就可以实现),而且也没有 ...

  5. Android中ListView的几种常见的优化方法

    Android中的ListView应该算是布局中几种最常用的组件之一了,使用也十分方便,下面将介绍ListView几种比较常见的优化方法: 首先我们给出一个没有任何优化的Listview的Adapte ...

  6. (转)Android之ListView原理学习与优化总结

    转自: http://jishu.zol.com.cn/12893.html 在整理前几篇文章的时候有朋友提出写一下ListView的性能优化方面的东西,这个问题也是小马在面试过程中被别人问到的….. ...

  7. ym——Android之ListView性能优化

    转载请注明本文出自Cym的博客(http://blog.csdn.net/cym492224103),谢谢支持! Android之ListView性能优化 假设有看过我写过的15k面试题的朋友们一定知 ...

  8. wemall app商城源码Android之ListView异步加载网络图片(优化缓存机制)

    wemall-mobile是基于WeMall的android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.本文分享wemall app商城源码Android之L ...

  9. android listview优化:滑动时颜色错乱问题

      最近android的listview写多了,也学习了各种listview的优化,列如viewHolder的使用.今天做item颜色设置时遇到一个新的问题.我这里设置“未完成”是灰色的,“已完成”是 ...

随机推荐

  1. 如何运用GitHub来提高生产效率

    这是一篇GitHub的入门级文章,主要针对git的初学者.我们将讨论初学者最关心的一些问题,如:为什么我们要使用GitHub,它的应用有哪些,如何运用它去帮助我们提高工作效率,以及它的基本用法有哪些. ...

  2. Excel 生成SQL

    '"&A21&"'   Excel 中要做字符串连接 "& + 单元格地址 + &", 如果单纯做测试在某个单元格中测试输出内容 ...

  3. phpstudy APACHE支持.htaccess以及 No input file specified解决方案

    APACHE支持.htaccess以及 No input file specified解决方案 你的Apache安装文件夹conf里找到httpd.conf文件 索LoadModule rewrite ...

  4. ThreadLocal 原理解析

    1.对Thread local 理解 ThreadLocal 是为了解决线程间同步而创建的一个新的思路.简单来说就是每个线程都保存一个变量副本. 如果在Thread 内部定义一个field变量,也可以 ...

  5. 71、django之Ajax续

    接上篇随笔.继续介绍ajax的使用. 上篇友情连接:http://www.cnblogs.com/liluning/p/7831169.html 本篇导航: Ajax响应参数 csrf 跨站请求伪造 ...

  6. C#提取字符串中的数字字符串

    1               }

  7. c#简单实现二维数组和二维数组列表List<>的转置

    刚看到网上一篇文章里用sql实现了行列转置.sql server 2005/2008只用一个pivot函数就可以实现sql server 2000很多行的复杂实现.提到转置,立刻想起还在求学阶段曾经做 ...

  8. python 中 urlparse 模块介绍

    urlparse模块主要是用于解析url中的参数  对url按照一定格式进行 拆分或拼接 1.urlparse.urlparse 将url分为6个部分,返回一个包含6个字符串项目的元组:协议.位置.路 ...

  9. [S]SQL SERVER数据库维护与重建索引

    第一步:查看是否需要维护,查看扫描密度/Scan Density是否为100% declare @table_id int set @table_id=object_id('表名') dbcc sho ...

  10. Python 函数返回值

    本章详细介绍 返回值: 0x 00 返回值简介 0x 01 指定返回值与隐含返回值 0x 02 return 语句位置与多条 return 语句 0x 03 返回值类型 0x 04 函数嵌套 0x 0 ...