Typed Arrays通过ArrayBuffer实现对二进制数据的高效操作,需用视图如Int32Array或DataView访问,支持多种数据类型和字节序控制,适用于处理图像、音频等原始数据。

JavaScript 的 Typed Arrays 提供了一种高效处理二进制数据的方式,特别适用于操作原始二进制内容,比如图像、音频、网络协议或文件读取。它们不能像普通数组那样动态增长,但能直接映射到内存中的 ArrayBuffer,实现对字节的精确控制。
理解 ArrayBuffer 和视图
Typed Arrays 的核心是 ArrayBuffer,它代表一块固定的连续内存区域,存储原始二进制数据。你不能直接操作 ArrayBuffer 中的数据,必须通过“视图”(View)来访问,最常见的就是 Typed Array 视图,如 Int8Array、Uint32Array、Float64Array 等。
例如,创建一个 8 字节的缓冲区:
const buffer = new ArrayBuffer(8);
然后你可以在这个 buffer 上创建不同类型的视图:
立即学习“Java免费学习笔记(深入)”;
const view1 = new Int32Array(buffer); // 可存 2 个 32 位整数
view1[0] = 42;
view1[1] = -1;
常用 Typed Array 类型
每种 Typed Array 对应不同的数据类型和字节长度:
Int8Array:8 位有符号整数(-128 到 127) Uint8Array:8 位无符号整数(0 到 255) Int16Array:16 位有符号整数 Uint16Array:16 位无符号整数 Int32Array:32 位有符号整数 Uint32Array:32 位无符号整数 Float32Array:32 位浮点数 Float64Array:64 位浮点数
同一个 ArrayBuffer 可以被多个不同类型的视图引用,这在需要按不同格式解析同一段数据时非常有用。
实际使用示例:写入与读取混合数据
假设你要将一个整数和一个浮点数写入二进制缓冲区:
const buffer = new ArrayBuffer(8);
const intView = new Int32Array(buffer, 0, 1); // 前 4 字节存整数
const floatView = new Float32Array(buffer, 4, 1); // 后 4 字节存浮点数
intView[0] = 100;
floatView[0] = 3.14;
// 读取时也可用 Uint8Array 查看每个字节
const bytes = new Uint8Array(buffer);
console.log(bytes); // 输出 8 个字节的值
与 DataView 配合处理复杂格式
如果数据涉及多种字节序(endianness)或非对齐访问,建议使用 DataView。它提供了更细粒度的读写方法,可指定是否使用小端序。
const buffer = new ArrayBuffer(8);
const dataView = new DataView(buffer);
dataView.setInt32(0, 255, true); // 小端序写入 32 位整数
dataView.setFloat32(4, 1.5, true); // 小端序写入 32 位浮点数
console.log(dataView.getInt32(0, true)); // 读取验证
基本上就这些。Typed Arrays 让 JavaScript 能像系统语言一样操作内存,配合 XMLHttpRequest、Fetch、WebSocket 或 File API 使用时,能高效处理底层二进制流。关键是理解 ArrayBuffer 是数据容器,Typed Array 或 DataView 是访问它的工具。不复杂但容易忽略细节,比如字节对齐和端序问题。
以上就是怎样使用 JavaScript 的 Typed Arrays 处理二进制数据?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1523354.html
微信扫一扫
支付宝扫一扫