Android 开发笔记: LRU 算法的使用

Android 开发学习笔记(一) LRU算法的使用

  • 关于LRU的定义:
 L RU是Least Recently Used 近期最少使用算法。是一种置换算法,
百度百科是这么介绍的:内存管理的一种页面置换算法,对于在内存中但又不用的数据块(内存块)叫做LRU,操作系统会根据哪些数据属于LRU而将其移出内存而腾出空间来加载另外的数据。
  • 在Android中的应用:Android提供了LruCache 类来 实现Android缓存的lru算法;
  • 在Android中显示单个图片,加载单个网络图片是比较简单的,而多个图片同时加载时,就会变的比较复杂,比如ListView,GridView等控件,一般处理的方式有多线程加载(使用Thead + handle)的方式,还有异步加载(AsyncTask)。要提高体验度可以使用Lru算法,做缓存的处理。
  • 使用方法;
  • 翻看源码可以看出 LruCache类是使用的 LinkedHashMap<K, V> map;来实现缓存的,所以存取的用法基本与map类似;
    private LruCache<String ,Bitmap> caches;
    	//初始化 LruCache
       	public void init LruCache(){
            	//获取运行时的内存,
            	int maxMemory = (int) Runtime.getRuntime().maxMemory();
            	//取 内存的1/4 作为缓存的大小;
            	int cacheSize = maxMemory / 4;
    		caches = new LruCache<String, Bitmap>(cacheSize){ 
    			@Override 
    			protected int sizeOf(String key, Bitmap value) {
    			 return value.getByteCount(); 
    			}
    		};
        	}
    	//存
    	public void addBitmap(String url,Bitmap bitmap){
    		if(caches.get(url) == null){
    			caches.put(url,bitmap);
    		}
    	}
    	//取
    	public Bitmap getBitmap(String url){
    		return caches.get(url);
    	}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值