首先定义listView
布局文件就不说了,一个是activity对应的布局,一个是listview中的item布局。(这个如果不知道就百度吧,应该很多)
首先是把这个listView显示出来,在activity中两个步骤:
1:找到listview对应的布局 xxx = (强转)findviewbyid(对应id)
2:设置适配器: xxx.setadapt(这里放适配器);
3:新建适配器: new myadapt(这里可以选择实现adapter的接口,也可以选择继承baseadapter,区别在于baseadapt已经辅助实现了一些虚函数,所以我们不需要再去写那么多方法,使代码看起来比较混乱)
public class MyListAdapter extends BaseAdapter
{
public int getCount()
{
return blcaknumberlist.size();
}
public Object getItem(int position)
{
return null;
}
public long getItemId(int position)
{
return 0;
}
public View getView(int position, View convertView, ViewGroup parent)
{
//R.layout.list_blacknumber_item,这个是对应的item,就用不多说了吧
View view = View.inflate(getApplicationContext(),
R.layout.list_blacknumber_item, null);
//这里填写对应的item的数据填写,举个例子,假如item里面有一个id为 tv_list_num的textview
tv_list_num = (TextView) view.findViewById(R.id.tv_list_num);//获取了id
tv.settext(这里面填充需要往里面设置的内容);
return view;
}
}
4:到这里一个listview已经建立完成了。
如果就这样使用这个listview的话,我们可能会遇到的问题
1:如果数据量很庞大,那么打开那个activity的时候会出现一个白屏(如果这样的话,用户体验可谓糟糕之极呀)。
2:在滚动listView的时候会发现有一点卡,操作起来不流畅。
3:内存消耗很大,占用资源很多。
我逐个的说下优化方案:
对于第一点:出现的那个白屏,是由于在显示前做了一个比较耗时的操作,例如做了大量的数据查询或者操作。
解决方案1:就是将耗时操作放到线程中去做,这样耗时就不会造成屏幕卡住,而我们也可以用一些个比较美观的进度条来提示用户,我们目前正在进行的操作,这样用户应该就能比较舒服,不会认为你这个程序有毛病,而放弃这个程序。
解决方案2:就是将耗时操作分片。当然也建议放到线程中,其次,我们将一次性需要耗时很多的操作并不一次性做完,而是分次去做。形象的说:如果我们的电话本中有1000个号码,我们不需要去全部找出来,而是首先找出10条左右,正好显示一页,这样时间会很短,当我们去拖动这个listview的时候,我们再去加载其他的选项,表现在数据库上就是分页的查找了。
这样一优化,我想这个listview不单单是不会出现打开那个activity的时候卡住,而且很快,内存的消耗也降低了很多,原来需要将1000条数据全部加载到listview中,现在只需要加载几十条,那内存节省的肯定不是一点点吧??
对于第二点:listview拖动的时候卡,要解决这个问题首先我们要清楚原因:原因是1:我们由下向上拖动listview的时候,Android系统会自动的去销毁我们看不到的部分,并且创建进入我们视野的部分,所以上面的item会不停的被销毁,而进入窗口的activity会不停的被创建。而创建一个item会消耗大量的资源,所以导致卡。
解决方案:重复利用已经建好的item。这个思想是和线程池和连接池的思路是一样一样的。我们如果能看到的item的个数是9个,那么我们就建立10个这样的item,当我们一个item消失的时候,我们不是去销毁这个对象,而是把这个对象给我们即将进入视野的这个item去使用。这样就可以重复的利用这个item,就不需要重复的去创建item了,还会卡吗??
对于第三点,我想,第一点和第二点解决以后,第三点就迎刃而解了。