ArrayBuffer详细介绍

2024-01-23 18:12
文章标签 介绍 详细 arraybuffer

本文主要是介绍ArrayBuffer详细介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

ArrayBuffer

ArrayBuffer 对象用来表示通用的原始二进制数据缓冲区。

它是一个字节数组,通常在其他语言中称为“byte array”。你不能直接操作 ArrayBuffer 中的内容;而是要通过类型化数组对象或 DataView 对象来操作,它们会将缓冲区中的数据表示为特定的格式,并通过这些格式来读写缓冲区的内容。

相比于普通的 JavaScript 数组,ArrayBuffer 对象不会自动改变大小,这使得它更适合处理二进制数据,例如图像、音频、视频以及网络通信中的数据传输等

ArrayBuffer() 构造函数创建一个以字节为单位的给定长度的新 ArrayBuffer。你也可以从现有的数据(例如,从 Base64 字符串或者从本地文件)获取数组缓冲区。

ArrayBuffer 是一个可转移对象。

创建 ArrayBuffer

要创建一个新的 ArrayBuffer 实例,需要使用 ArrayBuffer 构造函数,并传入一个表示字节长度的整数值作为参数。例如,创建一个长度为 8 字节的 ArrayBuffer:

const buffer = new ArrayBuffer(8);

操作 ArrayBuffer

一旦创建了 ArrayBuffer,我们可以使用 DataView 或 TypedArray 来读取和写入其中的数据。

使用 DataView

DataView 对象提供了一种灵活的方式来读取和写入 ArrayBuffer 中的数据。可以使用 DataView 的方法来指定偏移量和数据类型,以读取或写入特定位置的数据。

下面是一个使用 DataView 进行读写操作的示例:

const buffer = new ArrayBuffer(8);
const view = new DataView(buffer);// 写入数据
view.setInt8(0, 42); // 在索引 0 处写入一个 8 位带符号整数// 读取数据
const value = view.getInt8(0); // 从索引 0 处读取一个 8 位带符号整数
console.log(value); // 输出: 42
使用 TypedArray

TypedArray 是一组特定类型的数组对象,它们被用来操作 ArrayBuffer 中的数据。不同的 TypedArray 对象对应于不同的数据类型,例如 Int8Array、Uint8Array、Int16Array、Float32Array 等等。

下面是一个使用 TypedArray 进行读写操作的示例:

const buffer = new ArrayBuffer(8);
const array = new Int8Array(buffer);// 写入数据
array[0] = 42; // 在索引 0 处写入一个 8 位带符号整数// 读取数据
const value = array[0]; // 从索引 0 处读取一个 8 位带符号整数
console.log(value); // 输出: 42

示例案例:计算数组平均值

下面是一个使用 ArrayBuffer 和 TypedArray 计算数组平均值的具体案例:首先创建一个包含 100 个随机数的数组,然后创建一个与数组长度相同的 ArrayBuffer,并使用 Float64Array 将数组数据拷贝到 ArrayBuffer 中。最后,使用 TypedArray 对象计算数组平均值并输出结果。

// 创建一个包含 100 个随机数的数组
const array = new Array(100).fill(0).map(() => Math.random() * 100);// 创建一个与数组长度相同的 ArrayBuffer
const buffer = new ArrayBuffer(array.length * Float64Array.BYTES_PER_ELEMENT);// 使用 Float64Array 将数组数据拷贝到 ArrayBuffer
const view = new Float64Array(buffer);
for (let i = 0; i < array.length; i++) {view[i] = array[i];
}// 使用 TypedArray 计算平均值
const sum = view.reduce((acc, val) => acc + val, 0);
const average = sum / array.length;console.log(average);

通过上述介绍和案例,我们可以看到 ArrayBuffer 在处理二进制数据时的高效性和灵活性。它为 JavaScript 开发者提供了更多处理原始二进制数据的能力,使得处理图像、音频、视频等应用场景更加便捷。

这篇关于ArrayBuffer详细介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/637101

相关文章

DeepSeek模型本地部署的详细教程

《DeepSeek模型本地部署的详细教程》DeepSeek作为一款开源且性能强大的大语言模型,提供了灵活的本地部署方案,让用户能够在本地环境中高效运行模型,同时保护数据隐私,在本地成功部署DeepSe... 目录一、环境准备(一)硬件需求(二)软件依赖二、安装Ollama三、下载并部署DeepSeek模型选

电脑密码怎么设置? 一文读懂电脑密码的详细指南

《电脑密码怎么设置?一文读懂电脑密码的详细指南》为了保护个人隐私和数据安全,设置电脑密码显得尤为重要,那么,如何在电脑上设置密码呢?详细请看下文介绍... 设置电脑密码是保护个人隐私、数据安全以及系统安全的重要措施,下面以Windows 11系统为例,跟大家分享一下设置电脑密码的具体办php法。Windo

JSON字符串转成java的Map对象详细步骤

《JSON字符串转成java的Map对象详细步骤》:本文主要介绍如何将JSON字符串转换为Java对象的步骤,包括定义Element类、使用Jackson库解析JSON和添加依赖,文中通过代码介绍... 目录步骤 1: 定义 Element 类步骤 2: 使用 Jackson 库解析 jsON步骤 3: 添

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ

四种Flutter子页面向父组件传递数据的方法介绍

《四种Flutter子页面向父组件传递数据的方法介绍》在Flutter中,如果父组件需要调用子组件的方法,可以通过常用的四种方式实现,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录方法 1:使用 GlobalKey 和 State 调用子组件方法方法 2:通过回调函数(Callb

Python进阶之Excel基本操作介绍

《Python进阶之Excel基本操作介绍》在现实中,很多工作都需要与数据打交道,Excel作为常用的数据处理工具,一直备受人们的青睐,本文主要为大家介绍了一些Python中Excel的基本操作,希望... 目录概述写入使用 xlwt使用 XlsxWriter读取修改概述在现实中,很多工作都需要与数据打交

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

Java操作PDF文件实现签订电子合同详细教程

《Java操作PDF文件实现签订电子合同详细教程》:本文主要介绍如何在PDF中加入电子签章与电子签名的过程,包括编写Word文件、生成PDF、为PDF格式做表单、为表单赋值、生成文档以及上传到OB... 目录前言:先看效果:1.编写word文件1.2然后生成PDF格式进行保存1.3我这里是将文件保存到本地后

windows系统下shutdown重启关机命令超详细教程

《windows系统下shutdown重启关机命令超详细教程》shutdown命令是一个强大的工具,允许你通过命令行快速完成关机、重启或注销操作,本文将为你详细解析shutdown命令的使用方法,并提... 目录一、shutdown 命令简介二、shutdown 命令的基本用法三、远程关机与重启四、实际应用