HarmonyOS鸿蒙Next中实现二进制数据处理功能示例代码
HarmonyOS鸿蒙Next中实现二进制数据处理功能示例代码
介绍
本示例基于Uint8Array实现二进制数据的处理,提供简单的处理二进制数据的操作,包括:读取单字节数据、读取无/有符号16位int数据、读取无/有符号32位int数据、读取无/有符号64位int数据、读取字符串数据以及读取浮点数数据。
效果预览
使用说明
本示例仅提供简单的二进制数据处理方式示例,不适用与处理复杂的二进制数据。
实现思路
- 读取单字节数据。
export class ParseUtil {
static readByte(b: Uint8Array, pos: number): number {
return b[pos] & 0xFF;
}
}
- 读取无符号16位int。
export class ParseUtil {
static readUInt16LE(b: Uint8Array, pos: number): number {
if (pos + 2 < b.length) {
pos = pos + 2;
return ((b[--pos] & 0xFF) << 8) | (b[--pos] & 0xFF);
} else {
return 0;
}
}
}
- 读取16位int。
export class ParseUtil {
static readInt16LE(b: Uint8Array, pos: number): number {
if (pos + 2 < b.length) {
pos = pos + 2;
let x = ((b[--pos] & 0xFF) << 8) | (b[--pos] & 0xFF);
return (x >= 32768) ? x - 65536 : x;
} else {
return 0;
}
}
}
- 读取无符号32位int。
export class ParseUtil {
static readUInt32LE(b: Uint8Array, pos: number): number {
if (pos + 4 < b.length) {
pos = pos + 4;
return ((b[--pos] & 0xFF) << 24) | ((b[--pos] & 0xFF) << 16) | ((b[--pos] & 0xFF) << 8) | (b[--pos] & 0xFF);
} else {
return 0;
}
}
}
- 读取32位int。
export class ParseUtil {
static readInt32LE(b: Uint8Array, pos: number): number {
if (pos + 4 < b.length) {
pos = pos + 4;
let x = ((b[--pos] & 0xFF) << 24) | ((b[--pos] & 0xFF) << 16) | ((b[--pos] & 0xFF) << 8) | (b[--pos] & 0xFF);
return ((x >= 2147483648) ? x - 4294967296 : x);
} else {
return 0;
}
}
}
- 读取无符号64位int。
export class ParseUtil {
// 64 位二进制 解析
static readUInt64LE(b: Uint8Array, pos: number): number {
if (pos + 7 < b.length) {
let result =
(((b[pos + 3] & 0xFF) << 24) | ((b[pos + 2] & 0xFF) << 16) | ((b[pos + 1] & 0xFF) << 8) |
((b[pos + 0] & 0xFF)));
// 32位表示高四位和
let result11 =
(((b[pos + 7] & 0xFF) << 24) | ((b[pos + 6] & 0xFF) << 16) | ((b[pos + 5] & 0xFF) << 8) |
((b[pos + 4] & 0xFF)));
return (result11 * 65536 * 65536 + result);
} else {
return 0;
}
}
}
- 读取64位int。
export class ParseUtil {
static readInt64LE(b: Uint8Array, pos: number): number {
if (pos + 7 < b.length) {
let result =
(((b[pos + 3] & 0xFF) << 24) | ((b[pos + 2] & 0xFF) << 16) | ((b[pos + 1] & 0xFF) << 8) |
((b[pos + 0] & 0xFF)));
// 32位表示高四位和
let result11 =
(((b[pos + 7] & 0xFF) << 24) | ((b[pos + 6] & 0xFF) << 16) | ((b[pos + 5] & 0xFF) << 8) |
((b[pos + 4] & 0xFF)));
let rs = (result11 * 65536 * 65536 + result);
if (rs > 4294967296 * 2147483648 - 1) {
rs -= 4294967296 * 4294967296;
}
return rs;
} else {
return 0;
}
}
}
- 读取字符串。
export class ParseUtil {
static readUTF(b: Uint8Array, pos: number): string {
// 前两个字节作为字符串的长度,判定字符串在二进制数据中的边界
let len = ParseUtil.readUInt16LE(b, pos);
pos = pos + 2;
let a: Uint8Array = new Uint8Array(len);
let ret = '';
try {
for (let i = 0; i < len; i++) {
let charCode = ParseUtil.readByte(b, pos);
a[i] = charCode;
pos++;
}
let textDecoder = util.TextDecoder.create('utf-8')
ret = textDecoder.decodeToString(a);
} catch (e) {
hilog.error(domainId, tag, e);
}
return ret;
}
}
- 读取浮点数。
export class ParseUtil {
static byteArrayToFloat(bytes: Uint8Array, pos: number): number {
if (pos + 3 < bytes.length) {
let b1 = bytes[pos + 3] & 0xFF;
let b2 = bytes[pos + 2] & 0xFF;
let b3 = bytes[pos + 1] & 0xFF;
let b4 = bytes[pos] & 0xFF;
let sign = 1 - (b1 >> 7 << 1); // sign = bit 0
let exp = (b1 << 1 & 0xFF | b2 >> 7) - 127; // exponent = bits 1..8
let sig = (b2 & 0x7F) << 16 | b3 << 8 | b4; // significand = bits 9..31
if (sig == 0 && exp == -127) {
return 0.0;
}
return (sign * (1 + Math.pow(2, -23) * sig) * Math.pow(2, exp));
} else {
return 0.0;
}
}
}
更多关于HarmonyOS鸿蒙Next中实现二进制数据处理功能示例代码的实战教程也可以访问 https://www.itying.com/category-93-b0.html
2 回复
在鸿蒙Next中处理二进制数据可以使用ArrayBuffer
和DataView
。示例代码如下:
// 创建4字节的ArrayBuffer
let buffer = new ArrayBuffer(4);
// 使用DataView读写数据
let view = new DataView(buffer);
view.setInt16(0, 32767); // 写入16位整数
view.setFloat32(2, 3.14); // 写入32位浮点数
// 读取数据
let intValue = view.getInt16(0);
let floatValue = view.getFloat32(2);
以上代码展示了如何创建二进制缓冲区并进行读写操作。DataView
提供不同类型数据的读写方法。
更多关于HarmonyOS鸿蒙Next中实现二进制数据处理功能示例代码的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html
这是一个很好的HarmonyOS二进制数据处理示例。代码展示了如何使用Uint8Array处理各种二进制数据类型:
- 单字节读取:使用简单的位掩码操作(0xFF)确保无符号值
- 16/32位整数处理:通过位移和位或操作组合多个字节,并处理有符号情况
- 64位整数处理:将64位拆分为两个32位部分处理
- 字符串处理:使用TextDecoder进行UTF-8解码
- 浮点数处理:解析IEEE 754浮点格式
代码考虑了边界检查(pos + n < length)和类型转换,适合HarmonyOS应用中的基本二进制协议解析。对于更复杂的场景,可能需要考虑使用DataView或专门的解析库。