ArrayBuffer,TypedArray,Int8Array 和Blob的关系

文章目录

    • 1.前言
    • [1. ArrayBuffer](#1. ArrayBuffer)
    • [2. TypedArray](#2. TypedArray)
      • [常见的 TypedArray 类型包括:](#常见的 TypedArray 类型包括:)
    • [3. Int8Array](#3. Int8Array)
    • [4. Blob](#4. Blob)
    • 5.关系总结

1.前言

在早期版本的 JavaScript 中,处理二进制数据(如图像、音频、视频等)的能力有限,通常需要依赖于服务器端的处理或使用插件(如 Flash)。随着 Web 技术的发展,特别是 HTML5 的引入,JavaScript 开始支持直接处理二进制数据的功能。

ArrArrayBuffer、TypedArray、Int8Array 和 Blob 是 JavaScript 中处理二进制数据的不同方式,它们之间有紧密的关系。它们也是 JavaScript 语言特性的一部分,专门为处理二进制数据而设计.下面将详细解释这些对象及其相互关系:

1. ArrayBuffer

  • 定义:ArrayBuffer 是一个固定大小的缓冲区,用于表示通用的、原始的二进制数据块。它本身不提供直接访问其内容的方法。
  • 用途:作为底层数据存储结构,为其他类型数组(如 TypedArray)提供内存支持。
  • 特点:
    • 不可变长度。
    • 可以通过视图(如 TypedArray 或 DataView)来访问和操作其中的数据。

2. TypedArray

  • 定义:TypedArray 是一组特定类型的数值数组,如 Int8Array、Uint8Array、Float64Array 等等。每个 TypedArray 类型对应一种基本数据类型,并且它们都基于 ArrayBuffer。
  • 用途:提供了对二进制数据更高级别的抽象,允许开发者以特定格式读写数据。
  • 特点:
    • 继承自 %TypedArray% 内部类,所有 TypedArray 类型共享相同的 API。
    • 每个元素占用固定的字节数,根据类型不同而变化。
    • 提供了类似数组的操作方法,如 get、set、subarray 等。

常见的 TypedArray 类型包括:

  • Int8Array:8-bit 整数,带符号。
  • Uint8Array:8-bit 整数,无符号。
  • Int16Array:16-bit 整数,带符号。
  • Uint16Array:16-bit 整数,无符号。
  • Int32Array:32-bit 整数,带符号。
  • Uint32Array:32-bit 整数,无符号。
  • Float32Array:32-bit 浮点数。
  • Float64Array:64-bit 浮点数。
  • Uint8ClampedArray:类似于 Uint8Array,但在设置超出范围的值时会自动夹紧到合法范围内。

3. Int8Array

  • 定义:Int8ArrayTypedArray 的一种,代表一个 8 位带符号整数数组。
  • 用途:用于处理小范围内的整数值,例如图像像素数据中的颜色分量。
  • 特点:
    • 每个元素占据 1 字节(8 位),可以表示从 -128127 的整数。
    • TypedArray 的子类,因此拥有所有 TypedArray 的特性。

4. Blob

  • 定义:Blob 表示不可变的、原始数据的类文件对象。它可以包含任何类型的数据,但通常与多媒体内容相关联
  • 用途:用于表示文件或文件片段,在文件上传、下载、在线预览等方面非常有用。
  • 特点:
    • 支持多种 MIME 类型。
    • 可以由多个 ArrayBufferTypedArray 或字符串组合而成。
    • 提供了 slice() 方法来创建新的 Blob 对象,该对象包含原 Blob 的一部分数据。

5.关系总结

  • ArrayBuffer 是底层的基础数据容器 ,它为 TypedArrayDataView 提供了实际的内存空间。你可以将 ArrayBuffer 视作一片连续的内存区域,而 TypedArrayDataView 则是这片内存的不同视角。
  • TypedArrayArrayBuffer 上的一个视图 ,它允许你以特定的数据类型(如整数或浮点数)来解释和操作这块内存。不同的 TypedArray 类型(如 Int8Array)决定了如何解析这块内存中的数据。
  • Int8ArrayTypedArray具体实现之一 ,专门用于处理 8 位带符号整数。它是 TypedArray 的子类,因此继承了所有相关的功能。
  • Blob 可以包含 ArrayBufferTypedArray,并且可以通过 FileReaderBlob.arrayBuffer() 方法转换回 ArrayBuffer。此外,Blob 还可以直接被用作文件流的一部分,适用于需要处理大文件或多媒体内容的应用场景。
相关推荐
渴望成为python大神的前端小菜鸟几秒前
JS宏任务 & 微任务 API 速查表
javascript
CodeSheep3 分钟前
裁员为什么先裁技术人员?网友一针见血
前端·后端·程序员
前端小王呀3 分钟前
自定义图表相关配置
android·前端·javascript
chilavert3188 分钟前
技术演进中的开发沉思-226 Ajax:前端兼容
javascript·架构
西西学代码8 分钟前
flutter---进度条
前端·javascript·flutter
时间的情敌24 分钟前
Vue3 和 Vue2 的核心区别
前端·javascript·vue.js
533_25 分钟前
[antv x6] 限制节点/边是否可以移动,移动时返回父节点,限制节点的移动范围
前端
步步为营DotNet28 分钟前
深入理解ASP.NET Core Middleware:构建高效Web应用的管道基石
前端·后端·asp.net
Aevget29 分钟前
DevExtreme JS & ASP.NET Core v25.2新功能预览 - 提升AI扩展功能
javascript·人工智能·ui·asp.net·界面控件·devextreme