当前位置: 首页 > 编程笔记 >

Android编程使用缓存优化ListView的方法

单修德
2023-03-14
本文向大家介绍Android编程使用缓存优化ListView的方法,包括了Android编程使用缓存优化ListView的方法的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了Android编程使用缓存优化ListView的方法。分享给大家供大家参考,具体如下:

ListView调用Adapter的getView方法获取每一个Item布局,将这些已经获得的Item布局放入缓存,将大大提高获取数据的效率,而且节省更多的流量,将数据进行缓存有两种方法是,一种是将内存缓存一种是sd卡缓存,在此分别进行演示。

sd卡缓存:

sd卡缓存是将下载的数据保存到sd卡中,当再次要获取数据时,首先要判断sd卡中是否存在,如果存在的话,就直接读取sd卡中的数据,如果不存在就从网上下载,然后保存到sd卡中

内存缓存:

内存优化是将获取到的数据存取到Map集合中,如果再次引用此数据,就直接从Map集合中获取,这样会导致一个问题,如果Map集合中的数据特别多,比如存取了100万条数据,这样有可能就会导致内存溢出。这是因为Map集合是强引用的集合,如何不把Map集合置为空的话,这个集合Java虚拟机就不会把它回收掉,当Map中的数据大小超过了内存大小就会导致内存溢出。为了避免这种异常我们要使用软引用softreference ,软引用和强引用的区别如下:

1. softreference 他是java虚拟机给我们提供的一个包装类型.

在包装类型里面的对象 一般情况下 ,java虚拟机会尽量长时间的保留这个对象
当java虚拟机内存不足的时候 java虚拟机就会回收 softreference里面的对象

2. hardreference 默认new出来的对象 都是这种强应用的类型

只要一个对象还保留的有引用,他就不会被垃圾回收

Map<String,Bitmap> map;

核心代码:

sd卡缓存

public class MyReadAdapter extends BaseAdapter{
 private List<CollectionEntry> entrys;
 public MyReadAdapter(CollectionFeed feeds) {
  entrys = feeds.getEntries();
 }
 public int getCount() {
  return entrys.size();
 }
 public Object getItem(int position) {
  return entrys.get(position);
 }
 public long getItemId(int position) {
  return position;
 }
 public View getView(int position, View convertView, ViewGroup parent) {
  View view = infalter.inflate(R.layout.myread_item, null);
  final ImageView iv = (ImageView) view.findViewById(R.id.book_img);
  //获取数据实体
  CollectionEntry ce = entrys.get(position);
  //获取图片地址
  String iconurl = ce.getSubjectEntry().getLink("image", null).getHref();
  int start = iconurl.lastIndexOf("/");
  int end = iconurl.length();
  final String iconname = iconurl.substring(start, end);
  //Environment.getExternalStorageDirectory()这个是sd卡目录
  File file = new File(Environment.getExternalStorageDirectory(),iconname);
  //获取sd卡缓存
  if(file.exists()){
   iv.setImageURI(Uri.fromFile(file));
   Log.i(TAG,"使用sd卡图片");
  }else{
   new LoadImageAsynTask(new ImageTaskCallback() {
   // 图片获取之后
   public void onImageLoaded(Bitmap bitmap) {
    if(bitmap!=null){
    iv.setImageBitmap(bitmap);
    //把图片存到sd卡上
    if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){
     try {
      File file = new File(Environment.getExternalStorageDirectory(),iconname);
      FileOutputStream fos = new FileOutputStream(file);
      bitmap.compress(CompressFormat.JPEG, 100, fos);
     } catch (Exception e) {
      e.printStackTrace();
     }
    }
    }else{
     iv.setImageResource(R.drawable.book);
    }
   }
   //图片获取之前
   public void beforeImageLoaded() {
    iv.setImageResource(R.drawable.book);
   }
  }).execute(iconurl);
  }
  return view;
 }
}

内存缓存

Map<String,SoftReference<Bitmap>> map;
public class MyReadAdapter extends BaseAdapter{
 private List<CollectionEntry> entrys;
 public MyReadAdapter(CollectionFeed feeds) {
  entrys = feeds.getEntries();
 }
 public int getCount() {
  return entrys.size();
 }
 public Object getItem(int position) {
  return entrys.get(position);
 }
 public long getItemId(int position) {
  return position;
 }
 public View getView(int position, View convertView, ViewGroup parent) {
  View view = infalter.inflate(R.layout.myread_item, null);
  final ImageView iv = (ImageView) view.findViewById(R.id.book_img);
  //获取到数据的实体
  CollectionEntry ce = entrys.get(position);
  //获取到图片的Url
  String iconurl = ce.getSubjectEntry().getLink("image", null).getHref();
  int start = iconurl.lastIndexOf("/");
  int end = iconurl.length();
  final String iconname = iconurl.substring(start, end);
  //使用内存缓存
  if(map!=null && map.get(iconname)!=null){
   iv.setImageBitmap(map.get(iconname).get());
   Log.i(TAG,"使用内存缓存");
  }
  else{
  new LoadImageAsynTask(new ImageTaskCallback() {
   // 图片获取之后
   public void onImageLoaded(Bitmap bitmap) {
    if(bitmap!=null){
    iv.setImageBitmap(bitmap);
    //存放到内存中,
    //软引用类型的bitmap
    map.put(iconname, new SoftReference<Bitmap>(bitmap));
    }else{
     iv.setImageResource(R.drawable.book);
    }
   }
   //图片获取之前
   public void beforeImageLoaded() {
    iv.setImageResource(R.drawable.book);
   }
  }).execute(iconurl);
  }
  return view;
 }
}

希望本文所述对大家Android程序设计有所帮助。

 类似资料:
  • When users hit the URL of your application they will need to download different assets. CSS, JavaScript, HTML, images and fonts. The great thing about Webpack is that you can stop thinking how you sho

  • 本文向大家介绍Android ListView介绍及优化方案,包括了Android ListView介绍及优化方案的使用技巧和注意事项,需要的朋友参考一下 xml设计 主java 老师笔记 # 5 listview 入门 ListView 是一个控件,一个在垂直滚动的列表中显示条目的一个控件,这些条目的内容来自于一个ListAdapter 。EditText Button TextView Ima

  • ES 内针对不同阶段,设计有不同的缓存。以此提升数据检索时的响应性能。主要包括节点层面的 filter cache 和分片层面的 request cache。下面分别讲述。 filter cache ES 的 query DSL 在 2.0 版本之前分为 query 和 filter 两种,很多检索语法,是同时存在 query 和 filter 里的。比如最常用的 term、prefix、rang

  • 本文向大家介绍Android中ListView的几种常见的优化方法总结,包括了Android中ListView的几种常见的优化方法总结的使用技巧和注意事项,需要的朋友参考一下 Android中的ListView应该算是布局中几种最常用的组件之一了,使用也十分方便,下面将介绍ListView几种比较常见的优化方法: 首先我们给出一个没有任何优化的Listview的Adapter类,我们这里都继承自B

  • 我在listview(又称convertView)中的视图缓存有点麻烦,下面是我的代码, 这是我日志中的输出 位置:0应用程序空 位置:1应用程序不为空 位置:2个APP Not NULL 位置:3应用程序不为空 . . . 位置:10应用程序不为空 这会造成灾难,因为这意味着在后台作业中传递的textview是相同的textview,而更改的视图是相同的textview,而另一个textview

  • ListView原理与优化 原理:ListView与Adapter ListView的实现离不开Adapter。可以这么理解:ListView中给出了数据来的时候,View如何实现的具体方式,相当于MVC中的V;而Adapter提供了相当于MVC中的C,指挥了ListView的数据加载等行为。 提一个问题:假设ListView中有10W个条项,那内存中会缓存10W个吗?答案当然是否定的。那么是如何