日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

内存缓存LruCache的简单使用

發布時間:2023/11/28 生活经验 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 内存缓存LruCache的简单使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

LruCache算法(Least Recently Used),也叫近期最少使用算法。 這個類非常適合用來緩存圖片,它的主要算法原理是把最近使用的對象用強引用存儲在 LinkedHashMap 中,并且把最近最少使用的對象在緩存值達到預設定值之前從內存中移除。

以下是使用 LruCache 來緩存圖片的例子:

private LruCache<String, Bitmap> mMemoryCache;@Override
protected void onCreate(Bundle savedInstanceState) {// 獲取到可用內存的最大值,使用內存超出這個值會引起OutOfMemory異常。// LruCache通過構造函數傳入緩存值,以KB為單位。int maxMemory = (int) (Runtime.getRuntime().maxMemory() / 1024);// 使用最大可用內存值的1/8作為緩存的大小。int cacheSize = maxMemory / 8;mMemoryCache = new LruCache<String, Bitmap>(cacheSize) {@Overrideprotected int sizeOf(String key, Bitmap bitmap) {// 重寫此方法來衡量每張圖片的大小,默認返回圖片數量。return bitmap.getByteCount() / 1024;}};
}public void addBitmapToMemoryCache(String key, Bitmap bitmap) {if (getBitmapFromMemCache(key) == null) {mMemoryCache.put(key, bitmap);}
}public Bitmap getBitmapFromMemCache(String key) {return mMemoryCache.get(key);
}

總結

以上是生活随笔為你收集整理的内存缓存LruCache的简单使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。