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程序设计有所帮助。
推荐阅读
-
Android编程使用缓存优化ListView的方法
-
Android编程使用Intent传递对象的方法分析
-
Android编程实现Listview点击展开和隐藏的方法
-
Android编程简单设置ListView分割线的方法
-
Android编程实现使用webView打开本地html文件的方法
-
Android编程使用GestureDetector实现简单手势监听与处理的方法
-
Android中ListView的几种常见的优化方法总结
-
Android编程使用ListView实现数据列表显示的方法
-
Android编程使用内容提供者方式(ContentProvider)进行存储的方法
-
Android编程使用HTTP协议与TCP协议实现上传文件的方法