ListView设置条目显示四种方案(listView的优化)

Listview是安卓中比不可少的一道风景,但是我用到listView的时候知道ListView容易造成内存的溢出,如果条目很少的话 ,我们一般的是直接使用,但是对于现在大量的ListView的显示,造成内存的溢出会很常见。话不多说了,先上代码

第一种很好理解,但是容易照成内存的溢出。

效果图(都是死代码 不多写了效果图)

item的代码

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
android:paddingTop="5dp"
android:paddingLeft="5dp"
    android:layout_height="match_parent"
    android:orientation="horizontal" >

    <ImageView
        android:id="@+id/iv"
        android:layout_width="50dp"
        android:layout_height="50dp"
        android:src="@drawable/ic_launcher" />

    <LinearLayout
        android:gravity="center_vertical"
        android:layout_width="match_parent"
        android:layout_height="50dp"
        android:orientation="vertical" >

        <TextView
            android:textColor="#000000"
            android:id="@+id/text1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="text1" />

        <TextView
            android:textColor="#000000"
            android:id="@+id/text2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="text2" />
    </LinearLayout>

</LinearLayout>

mainXML的代码

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <ListView

        android:id="@+id/lv"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content" />

</RelativeLayout>

主函数的代码

private ListView lv;
	private ArrayList<String> list = new ArrayList<String>();
	private ArrayList<Integer> iconlist=new ArrayList<Integer>();
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		setData();
		lv = (ListView) findViewById(R.id.lv);
		lv.setAdapter(new MyAdapter());

	}

	private void setData() {
		int[] icon = new int[] { R.drawable.a, R.drawable.b, R.drawable.c,
				R.drawable.d, R.drawable.e };

		for (int i = 0; i < icon.length; i++) {
			list.add("我是第" + i + "条目的数据");
			iconlist.add(icon[i]);
		}
	}

第一种:

下面是Adapter的代码(今天主要就是Adapter的优化),这一种方法是本人最最不建议的一种方法,了解就行,要是开发的时候这么写,哼哼,你的组长很有可能请你喝茶。

class MyAdapter extends BaseAdapter {

		@Override
		public int getCount() {
			return iconlist.size();
		}

		@Override
		public Object getItem(int position) {
			return position;
		}

		@Override
		public long getItemId(int position) {
			return iconlist.get(position);
		}

		@Override
		public View getView(int position, View convertView, ViewGroup parent) {
			View view=View.inflate(getApplicationContext(), R.layout.listviewitem,null);
			ImageView iv=(ImageView) view.findViewById(R.id.iv);
			TextView text1=(TextView) view.findViewById(R.id.text1);
			TextView text2=(TextView) view.findViewById(R.id.text2);

			iv.setImageResource(iconlist.get(position));
			text1.setText(list.get(position));
			text2.setText(list.get(position));
			return view;
		}
	}

第二种:

第二种方式是对convertView的复用,这个原理就是我门创建每一个Item的时候默认的会设置给convertView,至于converView的个数是多少,就是你手机能显示的listViewItem的条目的个数加一,为什么多个一?这个就是相当于交换值时用的temp变量一样,不再解释了,当我们的手滑动的时候,前一个item消失之后被下一个即将出现的Item服用,这样就省掉了很大很大的内存空间。

下面是代码(只是改变了getView方法的代码)

            @Override
		public View getView(int position, View convertView, ViewGroup parent) {
			View view = null;
			if (convertView != null) {
				view = convertView;
			} else {
				view = View.inflate(getApplicationContext(),
						R.layout.listviewitem, null);
			}
			ImageView iv = (ImageView) view.findViewById(R.id.iv);
			TextView text1 = (TextView) view.findViewById(R.id.text1);
			TextView text2 = (TextView) view.findViewById(R.id.text2);
			iv.setImageResource(iconlist.get(position));
			text1.setText(list.get(position));
			text2.setText(list.get(position));
			return view;
		}

第三种:

第三种的方式就是使用创建ViewHolder来绑定item这样的好处的效率更加的高,而且复用行非常的强这一种方式只能称之为半面向ViewHolder,ViewHolder内部类的代码如下。

static class MyViewholder {
		ImageView iv;
		TextView text1, text2;

	}

相应的getView方法:

@Override
		public View getView(int position, View convertView, ViewGroup parent) {
			MyViewholder viewholder = null;
			if (convertView == null) {
				viewholder = new MyViewholder();
				convertView = View.inflate(getApplicationContext(),
						R.layout.listviewitem, null);
				viewholder.iv = (ImageView) convertView.findViewById(R.id.iv);
				viewholder.text1 = (TextView) convertView.findViewById(R.id.text1);
				viewholder.text2 = (TextView) convertView.findViewById(R.id.text2);
				convertView.setTag(viewholder);
			} else {
				viewholder = (MyViewholder) convertView.getTag();
			}
			viewholder.iv.setImageResource(iconlist.get(position));
			viewholder.text1.setText(list.get(position));
			viewholder.text2.setText(list.get(position));
			return convertView;
		}

第四种:

完全面向ViewHolder 效率基本上一样的,就是面向的对象完全的变成了ViewHolder,这个主要用的就是面向对象的方法。

ViewHolder的代码

static class MyViewholder {
		private ImageView iv;
		private TextView text1, text2;
		//构造函数初始化控件
		MyViewholder(View convertView) {
			iv = (ImageView) convertView.findViewById(R.id.iv);
			text1 = (TextView) convertView.findViewById(R.id.text1);
			text2 = (TextView) convertView.findViewById(R.id.text2);
		}
		/**
		 * 提供获取MyViewholder的方法
		 * @param convertView
		 * @return
		 */
		public static MyViewholder getMyViewholder(View convertView){
			//获取viewHolder
			MyViewholder viewholder=(MyViewholder) convertView.getTag();
			if (viewholder==null) {
				//iewHolder为空了重新创建
				viewholder=new MyViewholder(convertView);
				convertView.setTag(viewholder);
			}
			return viewholder;
		}
	}

相应的getView的方法

@Override
		public View getView(int position, View convertView, ViewGroup parent) {
			if (convertView == null) {
				convertView = View.inflate(getApplicationContext(),
						R.layout.listviewitem, null);
			}
           MyViewholder myViewholder=MyViewholder.getMyViewholder(convertView);
           myViewholder.iv.setImageResource(iconlist.get(position));
           myViewholder.text1.setText(list.get(position));
           myViewholder.text2.setText(list.get(position));
			return convertView;
		}

到这里ListView的优化显示已经说完了。

时间: 2024-08-09 07:33:31

ListView设置条目显示四种方案(listView的优化)的相关文章

OpenStack部署到Hadoop的四种方案

随着企业开始同时利用云计算和大数据技术,现在应当考虑如何将这些工具结合使用.在这种情况下,企业将实现最佳的分析处理能力,同时利用私有云的快速弹性 (rapid elasticity) 和单一租赁的特性.如何协同效用和实现部署,是本文希望解决的问题. 一些基础知识 第一是OpenStack .作为目前最流行的开源云版本,它包括控制器.计算 (Nova).存储 (Swift).消息队列 (RabbitMQ) 和网络 (Quantum) 组件.图 1 提供了这些组件的一个图示(不包含 Quantum

四种方案解决ScrollView嵌套ListView问题(转)

在工作中,曾多次碰到ScrollView嵌套ListView的问题,网上的解决方法有很多种,但是杂而不全.我试过很多种方法,它们各有利弊. 在这里我将会从使用ScrollView嵌套ListView结构的原因.这个结构碰到的问题.几种解决方案和优缺点比较,这4个方面来为大家阐述.分析.总结. 实际上不光是ListView,其他继承自AbsListView的类也适用,包括ExpandableListView.GridView等等,为了方便说明,以下均用ListView来代表. 一. 为什么要使用S

四种方案解决ScrollView嵌套ListView问题

在工作中,曾多次碰到ScrollView嵌套ListView的问题,网上的解决方法有很多种,但是杂而不全.我试过很多种方法,它们各有利弊. 在这里我将会从使用ScrollView嵌套ListView结构的原因.这个结构碰到的问题.几种解决方案和优缺点比较,这4个方面来为大家阐述.分析.总结. 实际上不光是ListView,其他继承自AbsListView的类也适用,包括ExpandableListView.GridView等等,为了方便说明,以下均用ListView来代表. 一. 为什么要使用S

四种方案解决ScrollView嵌套ListView问题 [复制链接]

以下文章转自@安卓泡面 在工作中,曾多次碰到ScrollView嵌套ListView的问题,网上的解决方法有很多种,但是杂而不全.我试过很多种方法,它们各有利弊. 在这里我将会从使用ScrollView嵌套ListView结构的原因.这个结构碰到的问题.几种解决方案和优缺点比较,这4个方面来为大家阐述.分析.总结. 实际上不光是ListView,其他继承自AbsListView的类也适用,包括ExpandableListView.GridView等等,为了方便说明,以下均用ListView来代表

iOS设置圆角的四种方法

一.设置CALayer的cornerRadius cornerRadius属性影响layer显示的background颜色和前景框border,对layer的contents不起作用.故一个imgView(类型为UIImageView)的image不为空,设置imgView.layer的cornerRadius,是看不出显示圆角效果的,因为image是imgView.layer的contents部分. 这种情况下将layer的masksToBounds属性设置为YES,可以正确的绘制出圆角效果.

Netty解决粘包和拆包问题的四种方案

在RPC框架中,粘包和拆包问题是必须解决一个问题,因为RPC框架中,各个微服务相互之间都是维系了一个TCP长连接,比如dubbo就是一个全双工的长连接.由于微服务往对方发送信息的时候,所有的请求都是使用的同一个连接,这样就会产生粘包和拆包的问题.本文首先会对粘包和拆包问题进行描述,然后介绍其常用的解决方案,最后会对Netty提供的几种解决方案进行讲解.这里说明一下,由于oschina将"jie ma qi"认定为敏感文字,因而本文统一使用"解码一器"表示该含义 粘包

listview设置条目点击的时候不变色(让状态选择器不起作用)

未设置前的效果如下图: 很明显,“酷狗音乐”那个条目被点击的时候,条目背景变为蓝色,怎么去掉这个颜色呢? java代码可以这么写: 1 listView.setSelector(new ColorDrawable());//设置默认状态选择器为全透明,不传颜色就是没颜色 效果如下图:

统计二进制中1的个数(四种方案)

方案一:(只适合计算正数) #include<stdio.h> #include<stdlib.h> int main() { int num = 10;  //10的二进制数为1010 int count = 0; while (num) { if (num % 2 == 1)    //从最高位开始除,余数为1则为1,余数为2则为0 { count++;     //余数为1时计数加1 } num = num / 2;      //除以2相当于右移一位,即丢掉计数过的 } p

Android设置壁纸的几种方案

Android设置壁纸有许多方法,主要思路有两种: 1:通过WallpaperManager设置 2:通过系统程序设置 下文将分开说明: <1>通过WallpaperManager设置 该方法可以直接将图片置为壁纸,对于所有平台的Android系统都使用,但无法裁剪/调整图片. try { WallpaperManager wpm = (WallpaperManager) getActivity().getSystemService( Context.WALLPAPER_SERVICE); i