简介
MessagePack是一个非常高效的对象序列化库。它像JSON,但速度很快,而且很小。 现在MessagePack已经适配了3.0版本,可用于实现int64的复杂性编码。
下载安装
ohpm install @msgpack/msgpack
使用说明
编解码
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一下:欢迎大家关注工粽号<程序猿百晓生>,可以了解到以下知识点。
欢迎大家关注工粽号<程序猿百晓生>,0取以下学习清单:
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);
接口说明
| 方法名称 | 参数 | 功能描述 |
|---|---|---|
| encode(object: unknown) | object:编码内容 | 对象进行编码并返回编码器内部缓冲区的副本。 |
| decode(buffer: ArrayLike) | buffer:解码内容 。 | 对象进行解码。 |
| new Encoder() | 编码可复用构造器。 | |
| new Decoder() | 解码可复用构造器。 |
目录结构
|---- msgpackJavaScript
| |---- entry # 示例代码文件夹
| |---- Index.ets # 对外接口介绍
|---- EncodeDecodePage.ets # 普通编解码
|---- EncodeDecodeConstructorPage.ets # 通过构造器编解码
|---- MultiDecodePage.ets # 复杂对象解码
| |---- README.MD # 安装使用方法