您好,登錄后才能下訂單哦!
為什么要緩存圖片:
(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{ //根據圖片加載方法加載圖片 }
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。