Android之——ListView优化
转载请注明出处: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优化的更多相关文章
- Android之ListView优化
关于ListView几个方面的优化: ListView的大小设定固定值; 复用convertView, 使用ViewHolder提高在容器中查找组件的效率; 使用分页加载; 快速滚动时, item不显 ...
- 【Android】ListView 优化
重用 ListView Item ListView创建时其会创建屏幕可容纳数量的 Item.ListView 滚动时,刚消失的 item 会被保存到回收池中.新出现的 item 从回收池中获取避免反复 ...
- 【Android】listview优化
http://www.cnblogs.com/over140/archive/2011/03/23/1991100.html http://blog.sina.com.cn/s/blog_5fc933 ...
- Android之ListView性能优化——一行代码绑定数据——万能适配器
如下图,加入现在有一个这样的需求图,你会怎么做?作为一个初学者,之前我都是直接用SimpleAdapter结合一个Item的布局来实现的,感觉这样实现起来很方便(基本上一行代码就可以实现),而且也没有 ...
- Android中ListView的几种常见的优化方法
Android中的ListView应该算是布局中几种最常用的组件之一了,使用也十分方便,下面将介绍ListView几种比较常见的优化方法: 首先我们给出一个没有任何优化的Listview的Adapte ...
- (转)Android之ListView原理学习与优化总结
转自: http://jishu.zol.com.cn/12893.html 在整理前几篇文章的时候有朋友提出写一下ListView的性能优化方面的东西,这个问题也是小马在面试过程中被别人问到的….. ...
- ym——Android之ListView性能优化
转载请注明本文出自Cym的博客(http://blog.csdn.net/cym492224103),谢谢支持! Android之ListView性能优化 假设有看过我写过的15k面试题的朋友们一定知 ...
- wemall app商城源码Android之ListView异步加载网络图片(优化缓存机制)
wemall-mobile是基于WeMall的android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.本文分享wemall app商城源码Android之L ...
- android listview优化:滑动时颜色错乱问题
最近android的listview写多了,也学习了各种listview的优化,列如viewHolder的使用.今天做item颜色设置时遇到一个新的问题.我这里设置“未完成”是灰色的,“已完成”是 ...
随机推荐
- Python爬虫小实践:寻找失踪人口,爬取失踪儿童信息并写成csv文件,方便存入数据库
前两天有人私信我,让我爬这个网站,http://bbs.baobeihuijia.com/forum-191-1.html上的失踪儿童信息,准备根据失踪儿童的失踪时的地理位置来更好的寻找失踪儿童,这种 ...
- "use strict"详解
参考:http://www.ruanyifeng.com/blog/2013/01/javascript_strict_mode.html 目的: 消除JavaScript语法的一些不合理.不严谨之处 ...
- 4年java开发,该何去何从!
以前都是一直看,今天楼主第一次发博,还望各位不吝赐教. 今天也没别的要说的,就是吐槽一下楼主这几天的面试遭遇,感觉都有点怀疑人生了. 先说说楼主的情况吧,13年毕业本科计算机专业,到现在一直做java ...
- Java 核心内容相关面试题【1】
1.什么是 transient 变量? transient 变量是指不会被序列化的变量. 2.什么是同步(synchronization)? 在多线程环境中,同步是指控制多个线程访问共享资源的方式.没 ...
- 运放的PID电路
PID就是(比例(proportion).积分(integral).导数(derivative)),在工程实际中,应用最为广泛的调节器控制规律为比例.积分.微分控制,简称PID控制,又称PID调节. ...
- DbContext 和ObjectContext
近日学习新知识,用到CallContext数据槽,一直使用ObjectContext 但同时又在学习EF CodeFirst,上下文定义使用的 DbContext 这时问题来了,如何把DbContex ...
- nodejs a和b文件相互引用
//取自于node中文网 http://nodejs.cn/api/modules.html 当循环调用 require() 时,一个模块可能在未完成执行时被返回. 例如以下情况: a.js: con ...
- vimgdb安装以及使用
vimgdb安装 vim-7.3.tar.bz2http://www.vim.org/sources.phpvimgdb-for-vim7.3 (this patch) https://github. ...
- git 分支合并 强制合并
常用的提交流程git add *.XXXgit commit -m "备注....." # 提交到本地分支git fetch git merge #"合并远程分支情况,如 ...
- HashMap HashTable和ConcurrentHashMap的区别
HashMap和Hashtable都实现了Map接口,其主要的区别有:线程安全性,同步(synchronization),以及效率. HashMap和Hashtable基本上没啥区别,除了HashMa ...