简介
MessagePack是一个非常高效的对象序列化库。它像JSON,但速度很快,而且很小。
下载安装
ohpm install @msgpack/msgpack
OpenHarmony ohpm 环境配置等更多内容,请参考如何安装 OpenHarmony ohpm 包
使用说明
编解码
import { encode,decode } from "@msgpack/msgpack";
// 编码
let encoded:Uint8Array = encode({ foo: "bar" });
// 解码
let decodedObject = decode(encoded);
构造器编解码
import { Encoder,Decoder } from "@msgpack/msgpack";
// 编码可复用构造器
let encoder = new Encoder()
// 解码可复用构造器
let decoder = new Decoder()
// 编码
let encoded:Uint8Array = encoder.encode({ foo: "bar" });
// 解码
let decodedObject = decoder.decode(encoded);
DD一下:鸿蒙开发各类文档,可关注公Z号<程序猿百晓生>霍取。
1.OpenHarmony开发基础
2.OpenHarmony北向开发环境搭建
3.鸿蒙南向开发环境的搭建
4.鸿蒙生态应用开发白皮书V2.0 & V3.0
5.鸿蒙开发面试真题(含参考答案)
6.TypeScript入门学习手册
7.OpenHarmony 经典面试题(含参考答案)
8.OpenHarmony设备开发入门【最新版】
9.沉浸式剖析OpenHarmony源代码
10.系统定制指南
11.【OpenHarmony】Uboot 驱动加载流程
12.OpenHarmony构建系统--GN与子系统、部件、模块详解
13.ohos开机init启动流程
14.鸿蒙版性能优化指南
.......
数组对象编解码
import { encode,decodeMulti } from "@msgpack/msgpack";
let items = [
"foo",
10,
{
name: "bar",
},
[1, 2, 3],
];
// 将数组编码
let encodedItems = items.map((item) => encode(item));
// 创建空白缓存区用来后续存数据流
let encoded = new Uint8Array(encodedItems.reduce((p, c) => p + c.byteLength, 0));
let offset = 0;
// 空白缓存区存入数据流
for (let encodedItem of encodedItems) {
encoded.set(encodedItem, offset);
offset += encodedItem.byteLength;
}
let result: Array<unknown> = [];
// 解码后将数据存入result数组中
for (let item of decodeMulti(encoded)) {
result.push(item);
}
// result与items一致
expect(result).assertDeepEquals(items);
目录结构
|---- msgpackJavaScript
| |---- entry # 示例代码文件夹
| |---- Index.ets # 对外接口介绍
|---- EncodeDecodePage.ets # 普通编解码
|---- EncodeDecodeConstructorPage.ets # 通过构造器编解码
|---- MultiDecodePage.ets # 复杂对象解码
| |---- README.MD # 安装使用方法
约束与限制
在下述版本验证通过:
- DevEco Studio: 4.1 (4.1.3.322), SDK: API11 (4.1.0.36)
- DevEco Studio: 4.0 (4.0.3.513), SDK: API10 (4.0.10.10)
- DevEco Studio: 3.1 Beta2(3.1.0.400), SDK: API9 Release(3.2.11.9)