ZUI易入门Android之 MMKV

52 篇文章 0 订阅
16 篇文章 0 订阅

MMKV是什么?
     在Android开发过程中,我们经常会使用到一些存储。经常使用sharepreferences存储,当你的数据量在不需要使用数据库,但sharepreferences感觉又无法承载的时候,但性能卓越的存储框架,由腾讯旗下的微信开发—MMKV

今天我们主要从这几个方面来解释一下MMKV

MMKV存储优势
MMKV存储支持的数据类型
MMKV引入依赖
MMKV存储与获取
MMKV更多知识
MainActivity中使用代码
     一. MMKV存储优势
MMKV 是腾讯旗下开发的一款存储组件,采用 key - value方式存储,存储数据种类比较多,读写效率高
其有以下优点:

非常高效。MMKV使用mmap与文件保持内存同步,使用protobuf对数值进行编码/解码,充分利用Android,实现最佳性能。
多进程并发:MMKV支持进程之间的并发读写访问。
易于使用的。你可以随时使用MMKV。所有的更改都会立即保存,不需要同步,也不需要apply调用。
小。少数几个文件:MMKV包含进程锁、编码/解码帮助程序和mmap逻辑等等。很整洁。
大约60K的二进制大小:MMKV在每个架构上增加了大约60K的应用程序大小,而压缩(apk)时增加的就少多了。
二. MMKV存储支持的数据类型
MMKV存储数据以key-value形式存储,其接收以下数据类型:
boolean
int
long
float
double
String
set集合
byte[]数组
可序列化对象

三.MMKV引入依赖
依赖注入

在 App 模块的 build.gradle 文件里添加:

dependencies {
    implementation 'com.tencent:mmkv:1.0.22'
    // replace "1.0.22" with any available version
}
初始化

// 设置初始化的根目录
String dir = getFilesDir().getAbsolutePath() + "/mmkv_2";
String rootDir = MMKV.initialize(dir);
Log.i("MMKV", "mmkv root: " + rootDir);
四.MMKV存储与获取

/获得默认存储对象
      MMKV kv = MMKV.defaultMMKV();
      //存boolean值
      kv.encode("bool", true);
      boolean bValue = kv.decodeBool("bool");
      LogUtil.i("========bValue===="+bValue);
      //存int值
      kv.encode("int", Integer.MIN_VALUE);
      int iValue = kv.decodeInt("int");
      LogUtil.i("========iValue===="+iValue);
      //存long值
      kv.encode("long",60L);
      long longValue=kv.decodeLong("long");
      LogUtil.i("========longValue===="+longValue);
      //存float值
      kv.encode("float",30f);
      float floatValue=kv.decodeFloat("float");
      LogUtil.i("========floatValue===="+floatValue);
五.MMKV更多知识

MMKV还有更多功能,如:

自定义存储实例
自定义存储路径
设置是否加密及自定义加密的key
查询及删除等方法
// 添加/更新数据
kv.encode(key, value);
 
// 获取数据
int tmp = kv.decodeInt(key);
 
// 删除数据
kv.removeValueForKey(key);
SP 的迁移

private void testImportSharedPreferences() {
    MMKV mmkv = MMKV.mmkvWithID("myData");
    SharedPreferences old_man = getSharedPreferences("myData", MODE_PRIVATE);
    // 迁移旧数据
    mmkv.importFromSharedPreferences(old_man);
    // 清空旧数据
    old_man.edit().clear().commit();
    ......
}

 


————————————————
版权声明:本文为CSDN博主「行知天下」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_27248989/article/details/108630453

 

 

 

 

 

 

 

 

非常抱歉,我之前给出的示例使用了 jQuery,而你似乎更希望使用 ZUI(一款基于 Bootstrap 的前端框架)来渲染表格数据。下面是一个使用 ZUI 的示例代码: HTML 代码: ```html <table id="myTable" class="table"> <thead> <tr> <th>姓名</th> <th>年龄</th> </tr> </thead> <tbody></tbody> </table> ``` JavaScript 代码: ```javascript function renderTableData(data) { var tbody = $('#myTable tbody'); tbody.empty(); data.forEach(function(item) { var row = $('<tr></tr>'); row.append($('<td></td>').text(item.name)); row.append($('<td></td>').text(item.age)); tbody.append(row); }); } ``` 在上述代码,我们首先在 HTML 定义了一个表格,其包含了一个表头和一个空的表体。 然后,在 JavaScript 定义了 `renderTableData` 函数,传入一个数据数组 `data`。函数首先通过 `$('#myTable tbody')` 获取到表格的 `<tbody>` 元素,并使用 `empty()` 方法清空其内容。 接下来,我们使用 `forEach` 方法遍历数据数组的每个对象。对于每个对象,我们创建一个 `<tr>` 元素作为表格的一行,并使用 `text()` 方法将姓名和年龄添加到 `<td>` 元素。最后,将行添加到 `<tbody>` 。 通过调用 `renderTableData` 函数并传入相应的数据,我们就可以将数据渲染到使用 ZUI 框架的表格了。 请注意,为了使示例代码正常工作,你需要在 HTML 文件引入 ZUI 的相关 CSS 和 JavaScript 文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值