Skip to content

DovSnier/cacheKit

Repository files navigation

cacheKit

一个简单易用的cache 库,此版本的cache 支持多实例模式本地缓存过期模式.

特征

  • 简单
  • 实用
  • 方便
  • 多实例
  • 缓存过期

使用Gradle构建时添加一下依赖即可:

implementation 'com.dvsnier:cache:0.2.1'

使用前配置

需要的权限
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
初始化
    // 在application的onCreate中初始化
    @Override
    public void onCreate() {
        super.onCreate();
        CacheManager.getInstance().initialize(this);
        ...
    }
    
    @Override
    public void onTerminate() {
        super.onTerminate();
        CacheManager.getInstance().onDestroy();
    }
    

扩展

第一种,默认配置
//  在application的onCreate中初始化
    @Override
    public void onCreate() {
        super.onCreate();
//      默认磁盘配置512M 缓存空间
        CacheManager.getInstance().initialize(this);
        ...
    }
第二种,自定义配置
    // 在application的onCreate中初始化
    @Override
    public void onCreate() {
        super.onCreate();
//      自定义磁盘1G 缓存空间
        int cacheMaxSizeOfDisk = 1024 * 1024 * 1024; // 1G
        CacheManager.getInstance().initialize(new ICacheConfig.Builder(this).setCacheMaxSizeOfDisk(cacheMaxSizeOfDisk).create());
//      CacheManager.getInstance().initialize(new ICacheConfig.Builder(this).setAppVersion(getAppVersionCode(this)).setCacheMaxSizeOfDisk(cacheMaxSizeOfDisk).create());
        ...
    }

    public static int getAppVersionCode(Context context) {
            int versionCode = 1;
            PackageManager pm = context.getPackageManager();
            try {
                PackageInfo packInfo = pm.getPackageInfo(context.getPackageName(), 0);
                versionCode = packInfo.versionCode;
            } catch (NameNotFoundException e) {
                e.printStackTrace();
            }
            return versionCode;
        }

第三种,多实例配置

    // 在application的onCreate中初始化
    @Override
    public void onCreate() {
        super.onCreate();
//      自定义磁盘1G 缓存空间
        int cacheMaxSizeOfDisk = Double.valueOf(CacheStorage.INSTANCE().getFormatted(1, AbstractStorage.SCU.G)).intValue(); // 1G < Integer.MAX_VALUE ~ 2G
//      the configure cache alias, here in the downloads directory    
        CacheManager.getInstance().initialize(IType.TYPE_DOWNLOADS, new ICacheConfig.Builder(this)
                .setContext(this)
                .setAppVersion(getAppVersionCode(this))
                .setCacheMaxSizeOfDisk(cacheMaxSizeOfDisk)
//                .setUniqueName(IType.TYPE_DEFAULT)
                .setUniqueName(IType.TYPE_DOWNLOADS)
                .setDebug(true)     // debug mode
                .create());
        ...
    }

    public static int getAppVersionCode(Context context) {
            int versionCode = 1;
            PackageManager pm = context.getPackageManager();
            try {
                PackageInfo packInfo = pm.getPackageInfo(context.getPackageName(), 0);
                versionCode = packInfo.versionCode;
            } catch (NameNotFoundException e) {
                e.printStackTrace();
            }
            return versionCode;
        }

第四种,本地缓存过期模式配置

    // 在application的onCreate中初始化
    @Override
    public void onCreate() {
        super.onCreate();
//      自定义磁盘1G 缓存空间
        int cacheMaxSizeOfDisk = Double.valueOf(CacheStorage.INSTANCE().getFormatted(1, AbstractStorage.SCU.G)).intValue(); // 1G < Integer.MAX_VALUE ~ 2G
//      the configure cache alias, here in the downloads directory    
        CacheManager.getInstance().initialize(IType.TYPE_DOWNLOADS, new ICacheConfig.Builder(this)
                .setContext(this)
                .setAppVersion(getAppVersionCode(this))
                .setCacheMaxSizeOfDisk(cacheMaxSizeOfDisk)
                .setUniqueName(IType.TYPE_DOWNLOADS)
                .setCacheGenre(new CacheGenre.SCHEDULED())  // the Scheduled Mode, otherwise is default
//                .setDebug(true)
//                .setLevel(Level.VERBOSE)
                .create());

        CacheManager.getInstance().setOnTransactionSessionChangeListener(IType.TYPE_DOWNLOADS, new OnTransactionSessionChangeListener() {
            @Override
            public void onTransactionSessionChange(@NonNull String alias, @NonNull String key, @Nullable Object value) {
                Log.i(Debug.TAG(), String.format("the current cache engine(%s), key(%s) - value(%s)", alias, key, value));
            }
        });
        ...
    }

    public static int getAppVersionCode(Context context) {
            int versionCode = 1;
            PackageManager pm = context.getPackageManager();
            try {
                PackageInfo packInfo = pm.getPackageInfo(context.getPackageName(), 0);
                versionCode = packInfo.versionCode;
            } catch (NameNotFoundException e) {
                e.printStackTrace();
            }
            return versionCode;
        }

使用

1. 默认方式

    CacheManager.getInstance().put(key0, "测试数据: " + System.currentTimeMillis())
            .putString(key1, "测试字符串: " + view.toString())
            .putObject(key2, new Bean("cache object " + System.currentTimeMillis(), BuildConfig.VERSION_NAME))
            .putString(getKey(), view.toString())
            .commit();

2. 多实例方式

    CacheManager.getInstance().put(IType.TYPE_DOWNLOADS, getKey(), getValue())
            .commit(IType.TYPE_DOWNLOADS);

3. 本地缓存过期方式

    CacheManager.getInstance().put(IType.TYPE_DOWNLOADS, getKey(), getValue())
            .put(IType.TYPE_DOWNLOADS, key1, getValue(), 30, TimeUnit.SECONDS)
            .put(IType.TYPE_DOWNLOADS, key2, getValue(), 1, TimeUnit.MINUTES)
            .put(IType.TYPE_DOWNLOADS, String.valueOf(System.currentTimeMillis()), getValue(), 3, TimeUnit.SECONDS)
            .commit(IType.TYPE_DOWNLOADS);

4. 获取数据

    Object o0 = CacheManager.getInstance().get(key0);
    String o1 = CacheManager.getInstance().getString(key1);
    Object o2 = CacheManager.getInstance().getObject(key2);
    
    Object O3 = CacheManager.getInstance().get(IType.TYPE_DOWNLOADS, key1);
    Object O4 = CacheManager.getInstance().get(IType.TYPE_DOWNLOADS, key2);

5. 方法签名

说明

  • Y:支持; *: 原则上支持;
默认 多实例 缓存过期 说明 备注
put(K,V) Y *
putString(K,V) Y *
putInputStream(K,V) Y *
putObject(K,V) Y *
get(K) Y *
getString(K) Y *
getInputStream(K) Y *
getObject(K) Y *
put(K,V,D,U) * Y
putString(K,V,D,U) * Y
putInputStream(K,V,D,U) * Y
putObject(K,V,D,U) * Y
get(K) * Y
getString(K) * Y
getInputStream(K) * Y
getObject(K) * Y
put(Type,K,V) Y
putString(Type,K,V) Y
putInputStream(Type,K,V) Y
putObject(Type,K,V) Y
get(Type,K) Y
getString(Type,K) Y
getInputStream(Type,K) Y
getObject(Type,K) Y
put(Type,K,V,D,U) Y Y
putString(Type,K,V,D,U) Y Y
putInputStream(Type,K,V,D,U) Y Y
putObject(Type,K,V,D,U) Y Y
get(Type,K) Y Y
getString(Type,K) Y Y
getInputStream(Type,K) Y Y
getObject(Type,K) Y Y

FAQ

  1. 默认缓存文件保存目录为: /mnt/sdcard/Android/data/package_your_name/cache/
  2. 配置缓存(IType.TYPE_DOWNLOADS)文件保存目录为: /mnt/sdcard/Android/data/package_your_name/cache/downloads, 如果配置不符合规范,则提供的默认配置为: /mnt/sdcard/Android/data/package_your_name/cache/local
  • 0.0.6 版本的Cache SDK 和0.1.0 版本的Cache SDK 不兼容,如需简单使用缓存请使用0.0.6
  • 推荐0.2.1,本地缓存过期和持久化自由切换(冷切换),兼容0.1.0 版本,不兼容0.0.6 版本;

关于作者

  • Email: dovsnier@qq.com
  • 有任何建议或者使用中遇到问题都可以给我发邮件,欢迎技术交流QQ:578562841