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 对应不同的数据类型和字节长度:
大小仅1兆左右 ,足够轻便的商城系统; 易部署,上传空间即可用,安全,稳定; 容易操作,登陆后台就可设置装饰网站; 并且使用异步技术处理网站数据,表现更具美感。 前台呈现页面,兼容主流浏览器,DIV+CSS页面设计; 如果您有一定的网页设计基础,还可以进行简易的样式修改,二次开发, 发布新样式,调整网站结构,只需修改css目录中的css.css文件即可。 商城网站完全独立,网站源码随时可供您下载
- 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 是访问它的工具。不复杂但容易忽略细节,比如字节对齐和端序问题。









