深入浅出TypedArray:网络数据处理、WebGPU与加密实战
JavaScript的TypedArray是现代Web开发中处理二进制数据的利器。本文将结合网络数据传输、WebGPU编程和简单加密算法三个实战场景,带你领略TypedArray的强大能力。
一、TypedArray基础认知
TypedArray家族包括Int8Array、Uint16Array、Float32Array等11种视图类型(关于视图类型的解释请参看:深入理解 JavaScript 中的视图类型),它们共同操作ArrayBuffer底层二进制缓冲区。与传统Array相比:
// 普通数组
const arr = [1, 2, 3]; // 每个元素占8字节// TypedArray
const typedArr = new Int8Array([1, 2, 3]); // 每个元素占1字节
在 JavaScript 中, TypedArray 是一种用于处理二进制数据的数组类型,它允许直接操作底层内存中的数据。与传统的 JavaScript 数组( Array )不同, TypedArray 是类型化的,这意味着它只能存储特定类型的数据(如整数、浮点数等),并且在底层以连续的内存块形式存储。
1. TypedArray 的种类
JavaScript 提供了多种类型的 TypedArray ,每种类型对应一种数据格式,包括:
| 类型化数组类型 | 数据类型 | 字节 | 值范围 |
|---|---|---|---|
| Int8Array | 8位有符号整数 | 1 | -128 到 127 |
| Uint8Array | 8位无符号整数 | 1 | 0 到 255 |
| Uint8ClampedArray | 8位无符号整数(溢出时钳制) | 1 | 0 到 255 |
| Int16Array | 16位有符号整数 | 2 | -32768 到 32767 |
| Uint16Array | 16位无符号整数 | 2 | 0 到 65535 |
| Int32Array | 32位有符号整数 | 4 | -2147483648 到 2147483647 |
| Uint32Array | 32位无符号整数 | 4 | 0 到 4294967295 |
| Float32Array | 32位浮点数 | 4 | IEEE 754 单精度浮点数 |
| Float64Array | 64位浮点数 | 8 | IEEE 754 双精度浮点数 |
2. 创建 TypedArray
TypedArray 的创建通常基于一个共享的底层缓冲区,通常是 ArrayBuffer 或 SharedArrayBuffer 。例如:
const buffer = new ArrayBuffer(16); // 创建一个大小为 16 字节的缓冲区
const int8Array = new Int8Array(buffer); // 创建一个 Int8Array,映射整个缓冲区
console.log(int8Array.length); // 输出:16
你也可以指定缓冲区的偏移量和长度:
const int16Array = new Int16Array(buffer, 0, 4); // 从偏移量 0 开始,长度为 4 的 Int16Array
console.log(int16Array.length); // 输出:4
3. TypedArray 的特点
- 内存效率: TypedArray 在底层以连续的内存块存储数据,适合处理大量数据,如图像像素、音频样本等。
- 性能优势:由于数据类型固定, TypedArray 的访问和操作速度比普通数组更快。
- 共享缓冲区:多个 TypedArray 可以共享同一个底层缓冲区,它们的修改会相互影响。例如:
const buffer = new ArrayBuffer(8);
const int32Array = new Int32Array(buffer);
const uint8Array = new Uint8Array(buffer);int32Array[0] = 0x12345678; // 设置 32 位整数
console.log(uint8Array); // 输出:[120, 86, 52, 18](字节顺序取决于平台)
4. 使用场景
- 图像处理:操作像素数据(如 Uint8ClampedArray )。
- 音频处理:处理音频样本数据(如 Float32Array )。
- WebAssembly:与 WebAssembly 共享内存,用于高性能计算。
- 二进制数据处理:读取或写入二进制文件(如文件上传、下载)。
5. 与普通数组的互操作
TypedArray 和普通数组可以通过 Array.from() 或扩展运算符相互转换:
const typedArray = new Uint8Array([1, 2, 3]);
const regularArray = Array.from(typedArray); // 或 [...typedArray]
console.log(regularArray); // 输出:[1, 2, 3]
6. 注意事项
- 字节序问题: TypedArray 的字节序取决于运行环境(大端或小端)。如果需要跨平台操作,可能需要手动处理字节序。
- 性能优化: TypedArray 的性能优势在于处理大量数据时,对于小规模数据,普通数组可能更方便。
TypedArray 是 JavaScript 中用于高效处理二进制数据的强大工具。它提供了多种数据类型选择,支持共享缓冲区,并且在性能和内存效率上有显著优势。如果你需要处理图像、音频或其他二进制数据, TypedArray 是一个非常合适的选择。后面我们分别以网络数据处理、WebGPU编程与加密处理为例演示TypedArray在实际编程中的应用。
二、网络数据处理实战
1. 接收二进制数据
使用Fetch API获取PNG图片并解析元数据:
fetch('image.png').then(response => response.arrayBuffer()).then(buffer => {const view = new DataView(buffer);const pngHeader = String.fromCharCode(view.getUint8(1),view.getUint8(2),view.getUint8(3));console.log(`PNG标识:${pngHeader}`); // 输出PNG});
2. 处理WebSocket数据流
构建二进制协议解析器:
const ws = new WebSocket('wss://example.com/data');
ws.binaryType = 'arraybuffer';ws.onmessage = (event) => {const buffer = event.data;const dataView = new DataView(buffer);const protocolVersion = dataView.getUint8(0);const timestamp = dataView.getBigUint64(1);const payload = new Float32Array(buffer, 9);
};
三、WebGPU中的TypedArray应用
1. 创建顶点缓冲区
const vertices = new Float32Array([// 位置 // 颜色-0.5, -0.5, 1, 0, 0,0.5, -0.5, 0, 1, 0,0.0, 0.5, 0, 0, 1
]);const vertexBuffer = device.createBuffer({size: vertices.byteLength,usage: GPUBufferUsage.VERTEX,mappedAtCreation: true
});new Float32Array(vertexBuffer.getMappedRange()).set(vertices);
vertexBuffer.unmap();
2. 计算着色器数据交互
// CPU端数据准备
const inputData = new Uint32Array([1, 2, 3, 4, 5]);
const outputBuffer = device.createBuffer({size: inputData.byteLength,usage: GPUBufferUsage.STORAGE | GPUBufferUsage.COPY_SRC
});// GPU计算完成后读取数据
const result = new Uint32Array(inputData.length);
await device.queue.readBuffer(outputBuffer, 0, result.buffer);
四、数据加密案例:XOR加密
1. 加密函数实现
function xorEncrypt(key, str) {const encoder = new TextEncoder();const data = encoder.encode(str);const result = new Uint8Array(data.length);for (let i = 0; i < data.length; i++) {result[i] = data[i] ^ key.charCodeAt(i % key.length);}return result;
}
2. 完整加密/解密流程
// 加密过程
const original = "Secret Message";
const encrypted = xorEncrypt("mykey", original);// 传输加密数据(模拟)
const transmittedData = encrypted.buffer;// 解密过程
function xorDecrypt(key, buffer) {const data = new Uint8Array(buffer);const decoder = new TextDecoder();const result = new Uint8Array(data.length);for (let i = 0; i < data.length; i++) {result[i] = data[i] ^ key.charCodeAt(i % key.length);}return decoder.decode(result);
}console.log(xorDecrypt("mykey", transmittedData)); // 输出"Secret Message"
五、性能优化建议
- 内存复用:对频繁操作的数据使用单个ArrayBuffer
const sharedBuffer = new ArrayBuffer(1024);
const intView = new Int32Array(sharedBuffer);
const floatView = new Float32Array(sharedBuffer);
- 批量操作:使用set()代替循环赋值
const source = new Uint8Array(1024);
const target = new Uint8Array(2048);
target.set(source, 512); // 批量复制
- 视图转换:避免不必要的类型转换
// 高效转换
const uintArray = new Uint16Array(buffer);
const intArray = new Int16Array(uintArray.buffer);
六、总结
TypedArray在Web开发的各个领域发挥着关键作用,掌握TypedArray不仅能提升程序性能,更能打开处理二进制数据的新视野。随着WebAssembly和WebGPU等技术的发展,TypedArray的重要性将愈发凸显。
扩展阅读:
MDN TypedArray文档
WebGPU规范
ArrayBuffer与性能优化
相关文章:
深入浅出TypedArray:网络数据处理、WebGPU与加密实战
JavaScript的TypedArray是现代Web开发中处理二进制数据的利器。本文将结合网络数据传输、WebGPU编程和简单加密算法三个实战场景,带你领略TypedArray的强大能力。 一、TypedArray基础认知 TypedArray家族包括Int8Array、Uint16Array、Float32Array等11种视图类型&a…...
http 响应码影响 video 标签播放视频
背景 使用后端给的文件下载接口地址实现视频播放,但是 video 标签一直无法播放视频如下图,把接口地址放到浏览器请求能直接下载。但就是不能播放 原因 http 响应码不正确,返回201是无法播放视频200可以如下图 状态码的影响: 20…...
观察者模式原理详解以及Spring源码如何使用观察者模式?
前言 首先说明观察者模式,观察者模式,也叫发布-订阅模式,应该是用来处理对象间的一对多依赖关系的。当被观察者的状态变化时,所有依赖它的观察者都会得到通知并自动更新。 观察者模式的结构,通常包括Subject࿰…...
【Spring】Spring配置文件
目录 什么是配置文件? 配置文件的作用 SpringBoot配置文件 配置文件格式 配置文件的优先级 properties配置文件说明 properties基本语法 读取配置文件 properties缺点 yml配置文件说明 yml基本语法 使用yml连接数据库 yml配置不同数据类型及null 注意…...
MSI微星电脑冲锋坦克Pro Vector GP76 12UGS(MS-17K4)原厂Win11系统恢复镜像,含还原功能,预装OEM系统下载
适用机型:【MS-17K4】 链接:https://pan.baidu.com/s/1P8ZgXc6S_J9DI8RToRd0dQ?pwdqrf1 提取码:qrf1 微星笔记本原装出厂WINDOWS11系统自带所有驱动、出厂主题壁纸、系统属性专属联机支持标志、Office办公软件、MSI Center控制中心等预装…...
Unity合批处理优化内存序列帧播放动画
Unity合批处理序列帧优化内存 介绍图片导入到Unity中的处理Unity中图片设置处理Unity中图片裁剪 创建序列帧动画总结 介绍 这里是针对Unity序列帧动画的优化内容,将多个图片合批处理然后为了降低Unity的内存占用,但是相对的质量也会稍微降低。可自行进行…...
【Java】逻辑运算符详解:、|| 与、 | 的区别及应用
博客主页: [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: Java 文章目录 💯前言💯一、基本概念与运算符介绍💯二、短路与与非短路与:&& 与 & 的区别1. &&:短路与(AND)2. …...
深入解析 Flutter GetX
深入解析 Flutter GetX:从原理到实战 GetX 是 Flutter 中一个轻量级且功能强大的状态管理、路由管理和依赖注入框架。它以简单、快速、高效著称,适合从小型到大型项目的开发需求。GetX 的设计理念是一体化解决方案,通过一个框架解决状态管理…...
Java 大视界 -- 人才需求与培养:Java 大数据领域的职业发展路径(92)
💖亲爱的朋友们,热烈欢迎来到 青云交的博客!能与诸位在此相逢,我倍感荣幸。在这飞速更迭的时代,我们都渴望一方心灵净土,而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识,也…...
顺序表常用操作和笔试题
1、顺序表的常用操作 1.1 顺序表的创建 如下代码所示:创建了一个默认空间为10的整型顺序表,如果空间不足则会以1.5倍扩容。 List<Integer> list new ArrayList<>(); 创建一个空间为15的整型顺序表 List<Integer> list2 new ArrayL…...
List<Map<String, Object>> 如何对某个字段求和
在Java中,如果你有一个List<Map<String, Object>>的结构,并且你想要对某个特定字段进行求和,你可以使用Java 8的Stream API来简化这个过程。下面是一个示例代码,演示如何对某个字段进行求和。 假设你有一个List<M…...
2024亚马逊数据分析!
整体财务数据23 净销售额:全年净销售额达 6380 亿美元,同比增长 11%。 净利润:全年净利润为 592 亿美元,较上年同期的 304 亿美元增长 95%。 经营活动现金流:经营活动现金流达 1159 亿美元,同比增加了 36…...
foobar2000设置DSP使用教程及软件推荐
foobar2000安卓中文版:一款高品质手机音频播放器 foobar2000安卓中文版是一款备受好评的高品质手机音频播放器。 几乎支持所有的音频格式,包括 MP3、MP4、AAC、CD 音频等。不论是经典老歌还是最新的流行音乐,foobar2000都能完美播放。除此之…...
Apache Logic4j 库反序列化漏洞复现与深度剖析
前言 在渗透测试领域,反序列化漏洞一直是安全研究人员和攻击者关注的焦点。今天,我们将深入探讨 Apache Logic4j 库中的反序列化漏洞,详细了解其原理,并进行完整的复现演示。 一、漏洞原理 Apache Logic4j 库在处理对象的反序列…...
FPGA VIVADO:axi-lite 从机和主机
FPGA VIVADO:axi-lite 从机和主机 TOC在这里插入代码片 前言 协议就不详细讲解了,直接看手册即可。下面主要如何写代码和关键的时序。 此外下面的代码可以直接用于实际工程 一、AXI-LITE 主机 数据转axi lite接口: 读/写数据FIFO缓存 仲裁:…...
LabVIEW 中的 3dgraph.llb库
3dgraph.llb 库位于C:\Program Files (x86)\National Instruments\LabVIEW 2019\vi.lib\Platform目录下,是 LabVIEW 系统里用于 3D 图形相关操作的关键库。它为 LabVIEW 用户提供众多功能,可在应用程序内创建、显示和交互各类 3D 图形,极大增…...
【Linux】文件系统:文件fd
🔥个人主页:Quitecoder 🔥专栏:linux笔记仓 目录 01.回顾C文件接口02.系统文件I/O02.1 openflags 参数(文件打开模式)标记位传参1. 访问模式(必须指定一个)2. 额外控制标志…...
Vue学习记录19
TransitonGroup <TransitionGroup> 是一个内置组件,用于对 v-for 列表中的元素或组件的插入、移除和顺序改变添加动画效果。 和 <Transtion> 的区别 <TranstionGroup> 支持和 <Transtion> 基本相同的 props、CSS过渡 class 和 JavaScript…...
MATLAB更改图论的布局:设置layout
在图论那一章,我们讲过最小生成树和单源最短路径(见:从零开始学数学建模): 以最短路径那节课为例,把绘图pplot那部分代码写为: % plot绘图有很多参数可以设置,使图尽量美观 P plot…...
【分果果——DP(困难)】
题目 分析 分果果题解参考,下面是补充https://blog.csdn.net/AC__dream/article/details/129431299 关于状态 设f[i][j][k]表示第i个人取到的最后一个糖果编号是j,第i-1个人取到的最后一个糖果编号小于等于k时的最大重量的最小值 关于转移方程 关于 j …...
BetterJoy完整指南:轻松解决Switch控制器PC连接问题
BetterJoy完整指南:轻松解决Switch控制器PC连接问题 【免费下载链接】BetterJoy Allows the Nintendo Switch Pro Controller, Joycons and SNES controller to be used with CEMU, Citra, Dolphin, Yuzu and as generic XInput 项目地址: https://gitcode.com/gh…...
别再让PlatformNotSupportedException搞垮你的跨平台.NET应用:5个实战避坑技巧
别再让PlatformNotSupportedException搞垮你的跨平台.NET应用:5个实战避坑技巧 当你的.NET应用在Linux服务器上突然崩溃,或者在macOS开发机上抛出神秘异常时,PlatformNotSupportedException往往是最令人头疼的"刺客"。这个看似简单…...
终极指南:如何在Windows上轻松玩转经典Flash游戏与存档管理
终极指南:如何在Windows上轻松玩转经典Flash游戏与存档管理 【免费下载链接】CefFlashBrowser Flash浏览器 / Flash Browser 项目地址: https://gitcode.com/gh_mirrors/ce/CefFlashBrowser 你是否怀念那些曾经风靡一时的Flash游戏?当现代浏览器纷…...
别再手动改Word了!用docxtemplater的{{#each}}和{{#if}}语法,5分钟搞定批量合同生成
告别低效办公:用docxtemplater实现合同批量生成的终极指南 每次月底都要加班处理上百份员工合同?手动复制粘贴到眼花缭乱还总出错?作为经历过这种痛苦的企业HR,我发现了一个彻底改变工作方式的工具——docxtemplater。它不仅仅是一…...
GeoRA:几何感知的低秩适配优化技术解析
1. 项目概述:GeoRA的核心创新与价值 在大型语言模型(LLM)的强化学习可验证奖励(Reinforcement Learning with Verifiable Rewards, RLVR)场景中,参数高效微调(Parameter-Efficient Fine-Tuning,…...
音节划分中常用前缀列表总结
第一类:普通前缀(约80%,重音在后,前缀弱读) 重音影响:主重音落在紧接前缀后面的音节(词根第一音节),前缀本身弱读。 前缀 发音(弱读式) 含义 示例 重音影响 a- /ə/ 在...之上/进入/不 arise /əˈraɪz/ 出现 v. 主重音在后 ab- /əb/ 离开/偏离 abnormal /bˈnɔ…...
终极视频下载指南:如何使用QuickCut轻松保存B站、YouTube等平台视频
终极视频下载指南:如何使用QuickCut轻松保存B站、YouTube等平台视频 【免费下载链接】QuickCut Your most handy video processing software 项目地址: https://gitcode.com/gh_mirrors/qu/QuickCut QuickCut是一款功能强大的视频处理软件,尤其在…...
Fewshot Corp与卡内基梅隆发现:超15%AI测试题存在可被绕过漏洞
这项由Fewshot Corp与卡内基梅隆大学联合开展的研究,以预印本形式于2026年4月19日发布,论文编号为arXiv:2604.17596,研究团队来自两个机构,分别是专注于少样本学习应用的Fewshot Corp,以及在AI安全领域具有重要影响力的…...
状态空间模型与长序列建模:MemMamba的创新与实践
1. 状态空间模型与长序列建模的挑战在自然语言处理、生物信息学和时间序列分析等领域,处理超长序列数据已成为一项基础性挑战。传统序列建模方法在面对数千甚至数百万时间步的连续数据时,往往陷入效率与性能的两难境地。1.1 现有方法的局限性循环神经网络…...
单个成本小于1欧元,年产百万:陶瓷正畸3D打印走向量产 | TCT亚洲展全球首发新品专访
陶瓷正畸3D打印材料LithaBite AO250含99.99%高纯度氧化铝,可确保正畸托槽具有生物相容性且耐用,能以极低的成本满足正畸领域的高标准。该材料与俐陶智 LCM 3D打印技术及特定的热后处理配合使用时,可生产出半透明的陶瓷托槽。LithaBite AO 250…...
