码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 一文讲清楚什么是类型化数组、ArrayBuffer、TypedArray、DataView等概念


    为什么需要类型化数组

    JavaScript 类型化数组是一种类似数组的对象,并提供了一种用于访问原始二进制数据的机制。

    js 在处理图像、音频视频编辑等方面,通常需要处理大量相同类型的数据,比如一张图片的像素点数据,坐标数据等等。而使用普通的 js 数组,存储的对象能动态增多和减少,并且可以存储任何 JavaScript 值,性能可能会有问题。所以 js 引入了类型化数组。

    类型化数组的创建要明确数据类型和长度,所以处理起来效率会高很多,而且不支持 push pop 等操作。

    类型化数组的组成

    类型数组拆分为两部分:

    • 缓冲Buffer
    • 视图View

    缓冲由 ArrayBuffer 对象实现,描述的是一个数据块,并且不能访问。
    如果要访问,就要用到视图。
    有点像类和对象的概念。
    在这里插入图片描述

    缓冲Buffer

    缓冲由 ArrayBuffer 对象实现,也就是上图框起来的部分,ArrayBuffer对象代表原始的二进制数据,那么如何对缓存区部分进行操作呢?有两种方式:

    • 类型数组视图
    • 数据视图DataView

    视图View

    简单总结一下就是,TypedArray视图用来读写简单类型的二进制数据,DataView视图用来读写复杂类型的二进制数据。

    类型数组视图TypedArray

    https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Int8Array

    数据类型字节长度含义对应的 C 语言类型
    Int818 位带符号整数signed char
    Uint818 位不带符号整数unsigned char
    Uint8Clamped18 位不带符号整数(自动过滤溢出)unsigned char
    Int16216 位带符号整数short
    Uint16216 位不带符号整数unsigned short
    Int32432 位带符号整数int
    Uint32432 位不带符号的整数unsigned int
    Float32432 位浮点数float
    Float64864 位浮点数double

    语法:

    new Int8Array(length);
    new Int8Array(typedArray);
    new Int8Array(object);
    new Int8Array(buffer [, byteOffset [, length]]);
    
    • 1
    • 2
    • 3
    • 4

    举例:

    // 以长度参数构造对象
    var int8 = new Int8Array(2);
    int8[0] = 42;
    console.log(int8[0]); // 42
    console.log(int8.length); // 2
    console.log(int8.BYTES_PER_ELEMENT); // 1
    
    // 以数组构造对象
    var arr = new Int8Array([21,31]);
    console.log(arr[1]); // 31
    
    // 从另一数组构造对象
    var x = new Int8Array([21, 31]);
    var y = new Int8Array(x);
    console.log(y[0]); // 21
    
    // 从 ArrayBuffer 构造对象
    var buffer = new ArrayBuffer(8);
    var z = new Int8Array(buffer, 1, 4);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    数据视图DataView

    语法:

    new DataView(buffer [, byteOffset [, byteLength]])
    
    • 1

    byteOffset:此 DataView 对象的第一个字节在 buffer 中的字节偏移。如果未指定,则默认从第一个字节开始。
    byteLength:此 DataView 对象的字节长度。如果未指定,这个视图的长度将匹配 buffer 的长度。

    // create an ArrayBuffer with a size in bytes
    const buffer = new ArrayBuffer(16);
    
    // Create a couple of views
    const view1 = new DataView(buffer);
    const view2 = new DataView(buffer, 12, 4); //from byte 12 for the next 4 bytes
    view1.setInt8(12, 42); // put 42 in slot 12
    
    console.log(view1.getInt8(12));
    console.log(view2.getInt8(0));
    // expected output: 42
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    提供的方法有很多如下:
    https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/DataView
    在这里插入图片描述

    实例

    使用 canvas 画出图片后,可以拿到图片每个像素点 rgba 的数据,这个数据就是存储在缓冲区中的,可以用 Uint8Array 来获取,具体看 js:使用canvas检测图片亮度

    参考文档

    https://www.jianshu.com/p/40d4a4d133e8
    https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Typed_arrays

  • 相关阅读:
    Java企业级实战项目
    学生成绩管理程序: 用面向对象的方法
    基于STM32单片机红外遥控自动泊车智能车
    做接口测试的流程一般是怎么样的?UI功能6大流程、接口测试8大流程这些你真的全会了吗?
    【技术分享】NetLogon于域内提权漏洞(CVE-2020-1472)
    利用SSLsplit+arpspoof 实现ARP欺骗劫持流量
    如何在两个不同的conda环境中实现jupyter notebook共同使用,避免重复下载
    web前端面试题附答案041 - 曾经一个百度面试官问我,localStorage可以存对象吗?
    ssprompt:一个LLM Prompt分发管理工具
    制定测试计划和测试用例
  • 原文地址:https://blog.csdn.net/weixin_43972437/article/details/125449368
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号