Javascript TypedArray 解惑:Uint8Array 与 Uint8ClampedArray 的区别

JS的类型数组大体可分为3类:无符号整数、有符号整数、浮点数。

Int8Array; Uint8Array; Uint8ClampedArray; Int16Array; Uint16Array; Int32Array; Uint32Array; Float32Array; Float64Array;

基本上都可以望文生义,看名字就知道怎么回事。

但是有一个例外 Uint8ClampedArray ,它与 Uint8Array 颇为相似,但又有所区别。

因为颜色数据刚好都是符合8位二进制的无符号整数,所以这两个类型在处理Canvas绘图数据时常常用到。

Uint8ClampedArray主要用于某些特殊场景,典型的就是 ImageData.

clamped这个词的字面意思是“紧固的,夹紧的”。

如果输入的值已经是0~255之间的整数,那么Uint8Array 与 Uint8ClampedArray的最终结果是一致的。


Uint8Array 与 Uint8ClampedArray 的区别,就在于处理不在该范围(0~255之间的整数)的输入数值的转换逻辑的差异。


Uint8Array采用的转换逻辑是ToUint8 . 

其中一个关键点是,它将输入数与256取模,将8个比特位转化为正整数

  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript中,`Uint8Array`是一种类型化数组(TypedArray),它用于表示一个包含8位无符号整数的固定长度数组。以下是`Uint8Array`的一些常用用法: 1. 创建一个`Uint8Array`对象: - 使用数组创建:`const arr = new Uint8Array([1, 2, 3, 4, 5]);` - 使用指定长度创建:`const arr = new Uint8Array(5);` 2. 获取`Uint8Array`的长度:`const length = arr.length;` 3. 访问和修改`Uint8Array`的元素: - 通过索引访问:`const value = arr[index];` - 通过索引修改:`arr[index] = newValue;` 4. 将`Uint8Array`对象转换为普通数组: - 使用`Array.from()`方法:`const plainArray = Array.from(arr);` - 使用`spread`运算符:`const plainArray = [...arr];` 5. 将普通数组转换为`Uint8Array`对象:`const arr = new Uint8Array([1, 2, 3, 4, 5]);` 6. 拷贝一个`Uint8Array`对象: - 浅拷贝:`const copy = Uint8Array.from(arr);` - 深拷贝:`const copy = new Uint8Array(arr);` 7. 连接多个`Uint8Array`对象: - 使用`concat()`方法:`const combined = Uint8Array.of(...arr1, ...arr2);` 8. 切片一个`Uint8Array`对象: - 使用`slice()`方法:`const slice = arr.slice(start, end);` 9. 迭代`Uint8Array`对象: - 使用`for...of`循环:`for (const value of arr) { ... }` - 使用`forEach()`方法:`arr.forEach((value, index) => { ... });` 这些是`Uint8Array`的一些常用用法和操作。除了`Uint8Array`,JavaScript还提供了其他类型化数组(如`Int8Array`、`Uint16Array`、`Float32Array`等),可以根据具体的需求选择适合的类型化数组来处理数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值