溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android——使用LruCache緩存圖片

發布時間:2020-07-05 10:57:16 來源:網絡 閱讀:1314 作者:wauoen 欄目:移動開發
  1. 為什么要緩存圖片:

    (1)根據具體設備的不同Android系統為每個應用分配了固定內存空間供應用使用;

    (2)圖片是一種很占內存的資源文件,如果界面中加載一張圖片還好說,如果要加載大量的圖片就會超過系統為應用分配的空間發生OOM異常,使程序奔潰;

2.LruCache:

    主要算法原理:將最近使用的對象用強應用存儲到LinkedHashMap中,在緩存值達到最大是把最近最少使用的對象從緩存區中移除;

3.實現步驟:

(1)創建緩存區:

//1.聲明Lrucache對象,和map類似也是采用鍵值對的形式,這里的key使用的是int
    private LruCache<Integer, Bitmap> bitmapcache = null; 
//2.為Lrucache分配內存空間
		//2.1首先獲取系統為該應用分配的最大空間,以kb為單位
		final int maxMemory = (int) (Runtime.getRuntime().maxMemory() / 1024);
		//2.2 將應用的內存的1/8作為該緩存區的大小實例化緩存區對象
		int cacheSize = maxMemory / 8;
		bitmapcache = new LruCache<Integer, Bitmap>(maxMemory){
			//2.3 規定緩存區中每個item的大小,即每個圖片的大小,默認是實際大??;(以kb為單位)
			protected int sizeOf(Integer key, Bitmap bitmap) {
				// The cache size will be measured in kilobytes rather than
				// number of items.
				return bitmap.getRowBytes() * bitmap.getHeight() / 1024;
			}
		};

(2)在加載圖片的方法中將得到的圖片放入緩存區

bitmapcache.put(bitmapId, bitmap);

(3)在使用Bitmap時判斷緩存區是否存在對應key值的bitmap對象,如果存在則直接讀取,如果不存在在調用加載圖片的方法進行獲??;

if(bitmapcache.get(bitmapId)!=null){
    bitmap = bitmapcache.get(bitmapId);
    iv.setImageBitmap(bitmap);
	}else{
    //根據圖片加載方法加載圖片
}


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女