【OpenHarmony】数据序列化系统:avro
本文介绍了一款基于OpenHarmony实现的Avro数据序列化系统,该系统将复杂数据结构转换为二进制格式,便于存储和传输。主要特点包括: 功能实现:支持丰富的数据结构序列化与反序列化 使用方法:提供了详细的安装指南和使用示例代码 接口说明:列出18个核心API,包括数据编码/解码、验证比较等功能 效果展示:通过动画演示了实际运行效果 适用场景:可作为容器文件用于持久化数据存储 项目已开源,开发者
·
往期推文全新看点(文中附带全新鸿蒙5.0全栈学习笔录)
✏️ 鸿蒙应用开发与鸿蒙系统开发哪个更有前景?
✏️ 嵌入式开发适不适合做鸿蒙南向开发?看完这篇你就了解了~
✏️ 对于大前端开发来说,转鸿蒙开发究竟是福还是祸?
✏️ 鸿蒙岗位需求突增!移动端、PC端、IoT到底该怎么选?
✏️ 市场巨变,移动开发行业即将迎来“第二春”?
✏️ 记录一场鸿蒙开发岗位面试经历~
✏️ 持续更新中……
简介
本软件是参照开源软件 apache avro 源码适配OpenHarmony实现的数据序列化系统,支持丰富的数据结构,将其转化成便于存储或传输的二进制数据格式。它同时也是一个容器文件,用于存储持久数据。
效果展示:

下载安装
ohpm install @ohos/avro-js
使用说明
示例代码
- 在page页面中引入avro
import avro from '@ohos/avro-js'
- 使用
let mapType: ESObject = avro.parse({ type: 'map', values: 'long' })
let petMap: petMapType = { key1: 12343, key2: 3445 };
let bufMap: ESObject = mapType.toBuffer(petMap); // Buffer containing 'Hi''s Avro encoding.
let mapSrc: ESObject = mapType.fromBuffer(bufMap); // === 'Hi'
let bufferStr = "";
for (let i = 0; i < bufMap.length; i++) {
bufferStr = bufferStr + bufMap[i];
}
this.mapTestResult = "MapType:{原始数据:" + JSON.stringify(petMap) + ",序列化后:" + bufferStr + ",还原数据:" + JSON.stringify(mapSrc) + "};";
console.info("----MapType--{original_data:" + JSON.stringify(petMap) + ",serialization:" + bufferStr + ",restore_data:" + JSON.stringify(mapSrc) + "}");
接口说明
avro.parse(schema, opts): 解析schema并返回对应的实例。type.toBuffer(val): 将给定值编码为二进制缓冲区。type.fromBuffer(buf, [resolver,] [noCheck]): 从二进制缓冲区创建新的实例。type.decode(buf, [pos,] [resolver]): 解码二进制缓冲区(Buffer)中的数据到给定的位置和解析器。type.encode(val, buf, [pos]): 将给定值编码为二进制缓冲区。type.fromString(str): 从字符串创建新的实例。type.toString([val]): 将给定值转换为字符串。type.isValid(val, [opts]): 检查给定值是否是有效值。type.clone(val, [opts]): 创建给定值的深度复制。type.compare(val1, val2): 比较两个值的大小。type.compareBuffers(buf1, buf2): 比较两个二进制缓冲区的大小。type.random(): 生成一个新的随机值。type.getName([noRef]): 获取类型的名称。type.getSchema([noDeref]): 获取类型的模式。type.getItemsType(): 获取数组或映射的类型。type.getAliases(): 获取类型的别名。type.getSize(): 获取类型的大小。type.getValuesType(): 获取枚举或固定类型的值类型。
目录结构
|---- avro
| |---- entry # 示例代码文件夹
| |---- library # avro库文件夹
| |---- README.md # 安装使用方法

更多推荐

所有评论(0)