ACache轻量级缓存框架

前言:关于该框架的评价,个人感觉还是可以的,可以保存多种类型的对象,主要特点是可以缓存bitmap、JSONObject、byte等对象,这方面比android原生的SharePreferences有优势,但对于boolean类型的数据处理好像不是很好,反正根据项目具体情况合理使用即可。

官方介绍
1、它可以缓存什么东西?
普通的字符串、JsonObject、JsonArray、Bitmap、Drawable、序列化的java对象,和 byte数据。
2、它有什么特色?
特色主要是:
1)轻,轻到只有一个JAVA文件。
2)可配置,可以配置缓存路径,缓存大小,缓存数量等。
3)可以设置缓存超时时间,缓存超时自动失效,并被删除。
4)支持多进程。

3、它在android中可以用在哪些场景?
1)替换SharePreference当做配置文件
2)可以缓存网络请求数据,比如oschina的android客户端可以缓存http请求的新闻内容,缓存时间假设为1个小时,超时后自动失效,让客户端重新请求新的数据,减少客户端流量,同时减少服务器并发量。

使用:

//初始化
ACache mCache = ACache.get(this);
//保存数据,文件名为testString
mCache.put("testString", "1111");
//读取数据
String testString = mCache.getAsString("testString");
//清空数据
mCache.remove("testString");

ACache框架(或称工具类,其实就是对特定的对象进行流的处理和转化而已)


      /**
       * 移除旧的文件
       * 
       * @return
       */
      private long removeNext() {
         if (lastUsageDates.isEmpty()) {
            return 0;
         }

         Long oldestUsage = null;
         File mostLongUsedFile = null;
         Set<Entry<File, Long>> entries = lastUsageDates.entrySet();
         synchronized (lastUsageDates) {
            for (Entry<File, Long> entry : entries) {
               if (mostLongUsedFile == null) {
                  mostLongUsedFile = entry.getKey();
                  oldestUsage = entry.getValue();
               } else {
                  Long lastValueUsage = entry.getValue();
                  if (lastValueUsage < oldestUsage) {
                     oldestUsage = lastValueUsage;
                     mostLongUsedFile = entry.getKey();
                  }
               }
            }
         }

         long fileSize = calculateSize(mostLongUsedFile);
         if (mostLongUsedFile.delete()) {
            lastUsageDates.remove(mostLongUsedFile);
         }
         return fileSize;
      }

      private long calculateSize(File file) {
         return file.length();
      }
   }

   /**
    * @title 时间计算工具类
    * @author 杨福海(michael) www.yangfuhai.com
    * @version 1.0
    */
   private static class Utils {

      /**
       * 判断缓存的String数据是否到期
       * 
       * @param str
       * @return true:到期了 false:还没有到期
       */
      private static boolean isDue(String str) {
         return isDue(str.getBytes());
      }

      /**
       * 判断缓存的byte数据是否到期
       * 
       * @param data
       * @return true:到期了 false:还没有到期
       */
      private static boolean isDue(byte[] data) {
         String[] strs = getDateInfoFromDate(data);
         if (strs != null && strs.length == 2) {
            String saveTimeStr = strs[0];
            while (saveTimeStr.startsWith("0")) {
               saveTimeStr = saveTimeStr
                     .substring(1, saveTimeStr.length());
            }
            long saveTime = Long.valueOf(saveTimeStr);
            long deleteAfter = Long.valueOf(strs[1]);
            if (System.currentTimeMillis() > saveTime + deleteAfter * 1000) {
               return true;
            }
         }
         return false;
      }

      private static String newStringWithDateInfo(int second, String strInfo) {
         return createDateInfo(second) + strInfo;
      }

      private static byte[] newByteArrayWithDateInfo(int second, byte[] data2) {
         byte[] data1 = createDateInfo(second).getBytes();
         byte[] retdata = new byte[data1.length + data2.length];
         System.arraycopy(data1, 0, retdata, 0, data1.length);
         System.arraycopy(data2, 0, retdata, data1.length, data2.length);
         return retdata;
      }

      private static String clearDateInfo(String strInfo) {
         if (strInfo != null && hasDateInfo(strInfo.getBytes())) {
            strInfo = strInfo.substring(strInfo.indexOf(mSeparator) + 1,
                  strInfo.length());
         }
         return strInfo;
      }

      private static byte[] clearDateInfo(byte[] data) {
         if (hasDateInfo(data)) {
            return copyOfRange(data, indexOf(data, mSeparator) + 1,
                  data.length);
         }
         return data;
      }

      private static boolean hasDateInfo(byte[] data) {
         return data != null && data.length > 15 && data[13] == '-'
               && indexOf(data, mSeparator) > 14;
      }

      private static String[] getDateInfoFromDate(byte[] data) {
         if (hasDateInfo(data)) {
            String saveDate = new String(copyOfRange(data, 0, 13));
            String deleteAfter = new String(copyOfRange(data, 14,
                  indexOf(data, mSeparator)));
            return new String[] { saveDate, deleteAfter };
         }
         return null;
      }

      private static int indexOf(byte[] data, char c) {
         for (int i = 0; i < data.length; i++) {
            if (data[i] == c) {
               return i;
            }
         }
         return -1;
      }

      private static byte[] copyOfRange(byte[] original, int from, int to) {
         int newLength = to - from;
         if (newLength < 0)
            throw new IllegalArgumentException(from + " > " + to);
         byte[] copy = new byte[newLength];
         System.arraycopy(original, from, copy, 0,
               Math.min(original.length - from, newLength));
         return copy;
      }

      private static final char mSeparator = ' ';

      private static String createDateInfo(int second) {
         String currentTime = System.currentTimeMillis() + "";
         while (currentTime.length() < 13) {
            currentTime = "0" + currentTime;
         }
         return currentTime + "-" + second + mSeparator;
      }

      /*
       * Bitmap → byte[]
       */
      private static byte[] Bitmap2Bytes(Bitmap bm) {
         if (bm == null) {
            return null;
         }
         ByteArrayOutputStream baos = new ByteArrayOutputStream();
         bm.compress(Bitmap.CompressFormat.PNG, 100, baos);
         return baos.toByteArray();
      }

      /*
       * byte[] → Bitmap
       */
      private static Bitmap Bytes2Bimap(byte[] b) {
         if (b.length == 0) {
            return null;
         }
         return BitmapFactory.decodeByteArray(b, 0, b.length);
      }

      /*
       * Drawable → Bitmap
       */
      private static Bitmap drawable2Bitmap(Drawable drawable) {
         if (drawable == null) {
            return null;
         }
         // 取 drawable 的长宽
         int w = drawable.getIntrinsicWidth();
         int h = drawable.getIntrinsicHeight();
         // 取 drawable 的颜色格式
         Bitmap.Config config = drawable.getOpacity() != PixelFormat.OPAQUE ? Bitmap.Config.ARGB_8888
               : Bitmap.Config.RGB_565;
         // 建立对应 bitmap
         Bitmap bitmap = Bitmap.createBitmap(w, h, config);
         // 建立对应 bitmap 的画布
         Canvas canvas = new Canvas(bitmap);
         drawable.setBounds(0, 0, w, h);
         // 把 drawable 内容画到画布中
         drawable.draw(canvas);
         return bitmap;
      }

      /*
       * Bitmap → Drawable
       */
      @SuppressWarnings("deprecation")
      private static Drawable bitmap2Drawable(Bitmap bm) {
         if (bm == null) {
            return null;
         }
         return new BitmapDrawable(bm);
      }
   }

}

以上就是全部内容,大家可以自个去试试,喜欢的朋友可以加个关注,以后有好的文章可以及时查阅讨论,有什么问题也可以留言,或者在微信公众号“技术帮团队”上找我们。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值