当前位置: 首页 > news >正文

深入浅出理解ArrayBuffer对象TypedArray和DataView视图

目录

举例理解

1. ArrayBuffer对象

2. TypedArray

3. DataView

总结

具体讲解 

1. ArrayBuffer对象

2. TypedArray

3. DataView

注意事项


举例理解

先举个简单的例子理解ArrayBuffer对象TypedArray和DataView视图的概念和之间的关系

1. ArrayBuffer对象

想象一个场景:你有一个装满水的长水管,这个水管就是一个ArrayBuffer。水管里的水是二进制数据,而水管本身则是用来存储这些数据的地方。

特点

  • 固定长度:这个水管一旦制作好了,长度就不能再改变。
  • 不能直接操作:你不能直接打开水管去喝水(即不能直接读取或修改二进制数据)。但是,你可以通过一些工具来帮助你。
2. TypedArray

继续上面的场景:现在,你想从水管里取水,但是水管太细了,手伸不进去。于是,你使用了一个特制的杯子(TypedArray),这个杯子有各种大小,可以对应水管里的不同水量。

类型

  • Int8Array:像是一个小杯子,每次只能取8位(1字节)的水。
  • Uint16Array:像是一个大杯子,每次可以取16位(2字节)的水。
  • ……以此类推。

用途

  • 当你需要按照特定的量(类型)来取水(读取数据)或倒水(写入数据)时,就可以使用对应的杯子(TypedArray)。
3. DataView

再次回到场景:但有时候,你可能想从水管的某个特定位置取一点水,或者同时取几种不同量的水。这时,使用杯子就不太方便了,因为杯子只能从头开始取水。

于是,你使用了一个吸管(DataView)。吸管可以让你选择从水管的哪个位置开始取水,以及取多少。

特点

  • 灵活:你可以决定从水管的哪个位置开始,以及取多少水。
  • 复杂:相对于杯子(TypedArray),使用吸管(DataView)可能需要更多的技巧和注意。
总结
  • ArrayBuffer就像是一个装满水的长水管,用来存储二进制数据。
  • TypedArray就像是一个特制的杯子,用来按照特定的量(类型)来取水或倒水。
  • DataView则像是一个吸管,可以灵活地选择从水管的哪个位置开始取水,以及取多少。
  • 如果ArrayBuffer中存储的二进制类型单一使用TypedArray反之使用DataView

通过以上例子相信你已经大致了解了这三者之间的关系,接下来具体看一下

具体讲解 

1. ArrayBuffer对象

用途与特性

ArrayBuffer对象是一个通用的、固定长度的原始二进制数据缓冲区。它常被用于存储和处理大量的二进制数据,比如图像、音频文件、网络通信中的数据等。

  • 固定长度:一旦创建,ArrayBuffer的大小就不能改变。这意味着,你需要在创建时确定所需的缓冲区大小。
  • 不能直接操作:你不能直接读写ArrayBuffer的内容。相反,你需要通过某种类型数组对象(如TypedArray)或DataView对象来访问和修改其中的数据。

创建与使用

你可以使用ArrayBuffer构造函数来创建一个新的ArrayBuffer对象,指定所需的字节长度作为参数。

const buffer = new ArrayBuffer(16); // 创建一个16字节的ArrayBuffer
2. TypedArray

用途与特性

TypedArray是一种特殊的数组,用于以特定的数值类型来读写ArrayBuffer的内容。它提供了多种类型,如Int8ArrayUint8ArrayFloat32Array等,用于存储不同范围和精度的数值。

  • 与ArrayBuffer关联TypedArray对象会关联一个ArrayBuffer,并且其元素会对应到ArrayBuffer的特定部分。
  • 类型安全:每个TypedArray都有一个固定的元素类型,这确保了存储的数据类型的一致性。

创建与使用

你可以通过传入一个ArrayBuffer对象来创建一个TypedArray

const buffer = new ArrayBuffer(16);
const int32View = new Int32Array(buffer); // 创建一个关联到buffer的Int32Array视图

你还可以使用TypedArray.set()方法来复制数据,或者使用.get()方法来获取数据。

3. DataView

用途与特性

DataView提供了一种用于读写ArrayBuffer内容的低级接口。与TypedArray不同,DataView允许你以任意顺序和字节序来读写ArrayBuffer的不同部分

  • 灵活性:你可以指定偏移量和字节序(大端或小端)来读取或写入数据。
  • 低级操作:相比于TypedArrayDataView提供了更底层的访问方式,但这也意味着操作起来可能更复杂一些。

创建与使用

你可以通过传入一个ArrayBuffer对象来创建一个DataView

const buffer = new ArrayBuffer(16);
const view = new DataView(buffer); // 创建一个关联到buffer的DataView

然后,你可以使用DataView提供的各种方法来读取或写入数据,如.getInt8().setUint16()等。

注意事项
  • 当使用TypedArrayDataView来读写ArrayBuffer时,要确保不要越界访问,否则可能会导致不可预测的行为。
  • ArrayBufferTypedArrayDataView共享相同的底层二进制数据。因此,对一个视图所做的修改会影响到其他视图和原始的ArrayBuffer
  • 当不再需要ArrayBufferTypedArrayDataView时,最好显式地解除对它们的引用,以便垃圾回收器能够回收它们占用的内存。
http://www.lryc.cn/news/333653.html

相关文章:

  • 人工智能 - 服务于谁?
  • 软考高级架构师:嵌入式系统的内核架构
  • 分布式锁实战
  • 【VMware Workstation】启动虚拟机报错“此主机支持 AMD-V,但 AMD-V 处于禁用状态”
  • 非关系型数据库(缓存数据库)redis的基础认知与安装
  • Go语言如何处理文件
  • Java基础知识总结(42)
  • C++ | Leetcode C++题解之第6题Z字形变换
  • JavaEE——手把手教你实现简单的 servlet 项目
  • X年后,ChatGPT会替代底层程序员吗?
  • OpenAI 推出新网络爬虫GPTBot,为GPT-5做准备
  • 【Easy云盘 | 第二篇】后端统一设计思想
  • c语言:模拟字符串拷贝功能(strcpy),面试题
  • 信创环境ES索引管理脚本:close, delete
  • torch-v1.3.1-build
  • C语言宏定义笔记
  • 设计模式:生活中的观察者模式
  • Qt实现Kermit协议(四)
  • 苏州金龙助力旅游客运加速蜕变
  • 头盔检测 | 基于Caffe-SSD目标检测算法实现的建筑工地头盔检测
  • Stable diffusion 加载扩展列表报错解决方法
  • Git(8)之分支间同步特定提交
  • 万得AI算法工程师一面面试题6道|含解析
  • 蓝桥杯23年第十四届省赛-异或和之和|拆位、贡献法
  • Unity进阶之路(1)回顾与思考
  • 【C语言】——指针八:指针运算笔试题解析
  • JVM字节码与类的加载——class文件结构
  • 小程序如何通过公众号发送新订单提醒
  • 聊聊公众号最让我不爽的两个痛点
  • 【leetCode】2810. 故障键盘