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卡缓存
publicclassMyReadAdapterextendsBaseAdapter{ privateList<CollectionEntry>entrys; publicMyReadAdapter(CollectionFeedfeeds){ entrys=feeds.getEntries(); } publicintgetCount(){ returnentrys.size(); } publicObjectgetItem(intposition){ returnentrys.get(position); } publiclonggetItemId(intposition){ returnposition; } publicViewgetView(intposition,ViewconvertView,ViewGroupparent){ Viewview=infalter.inflate(R.layout.myread_item,null); finalImageViewiv=(ImageView)view.findViewById(R.id.book_img); //获取数据实体 CollectionEntryce=entrys.get(position); //获取图片地址 Stringiconurl=ce.getSubjectEntry().getLink("image",null).getHref(); intstart=iconurl.lastIndexOf("/"); intend=iconurl.length(); finalStringiconname=iconurl.substring(start,end); //Environment.getExternalStorageDirectory()这个是sd卡目录 Filefile=newFile(Environment.getExternalStorageDirectory(),iconname); //获取sd卡缓存 if(file.exists()){ iv.setImageURI(Uri.fromFile(file)); Log.i(TAG,"使用sd卡图片"); }else{ newLoadImageAsynTask(newImageTaskCallback(){ //图片获取之后 publicvoidonImageLoaded(Bitmapbitmap){ if(bitmap!=null){ iv.setImageBitmap(bitmap); //把图片存到sd卡上 if(Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED)){ try{ Filefile=newFile(Environment.getExternalStorageDirectory(),iconname); FileOutputStreamfos=newFileOutputStream(file); bitmap.compress(CompressFormat.JPEG,100,fos); }catch(Exceptione){ e.printStackTrace(); } } }else{ iv.setImageResource(R.drawable.book); } } //图片获取之前 publicvoidbeforeImageLoaded(){ iv.setImageResource(R.drawable.book); } }).execute(iconurl); } returnview; } }
内存缓存
Map<String,SoftReference<Bitmap>>map; publicclassMyReadAdapterextendsBaseAdapter{ privateList<CollectionEntry>entrys; publicMyReadAdapter(CollectionFeedfeeds){ entrys=feeds.getEntries(); } publicintgetCount(){ returnentrys.size(); } publicObjectgetItem(intposition){ returnentrys.get(position); } publiclonggetItemId(intposition){ returnposition; } publicViewgetView(intposition,ViewconvertView,ViewGroupparent){ Viewview=infalter.inflate(R.layout.myread_item,null); finalImageViewiv=(ImageView)view.findViewById(R.id.book_img); //获取到数据的实体 CollectionEntryce=entrys.get(position); //获取到图片的Url Stringiconurl=ce.getSubjectEntry().getLink("image",null).getHref(); intstart=iconurl.lastIndexOf("/"); intend=iconurl.length(); finalStringiconname=iconurl.substring(start,end); //使用内存缓存 if(map!=null&&map.get(iconname)!=null){ iv.setImageBitmap(map.get(iconname).get()); Log.i(TAG,"使用内存缓存"); } else{ newLoadImageAsynTask(newImageTaskCallback(){ //图片获取之后 publicvoidonImageLoaded(Bitmapbitmap){ if(bitmap!=null){ iv.setImageBitmap(bitmap); //存放到内存中, //软引用类型的bitmap map.put(iconname,newSoftReference<Bitmap>(bitmap)); }else{ iv.setImageResource(R.drawable.book); } } //图片获取之前 publicvoidbeforeImageLoaded(){ iv.setImageResource(R.drawable.book); } }).execute(iconurl); } returnview; } }
希望本文所述对大家Android程序设计有所帮助。