标签:默认 返回 字节 属性 写入 网络 长度 第一个 svi
ArrayBuffer对象代表原始的二进制数据,TypedArray视图用来读写简单类型的二进制数据,DataView视图用来读写复杂类型的二进制数据
二进制数组并不是真正的数组,而是类似数组的对象
ArrayBuffer对象代表储存二进制数据的一段内存,它不能直接读写,只能通过视图(TypedArray视图和DataView视图)来读写,视图的作用是以指定格式解读二进制数据。
ArrayBuffer也是一个构造函数,可以分配一段可以存放数据的连续内存区域。
const buf = new ArrayBuffer(32);
上面代码生成了一段 32 字节的内存区域
返回所分配的内存区域的字节长度
允许将内存区域的一部分,拷贝生成一个新的ArrayBuffer对象
返回一个布尔值,表示参数是否为ArrayBuffer的视图实例
ArrayBuffer对象作为内存区域,可以存放多种类型的数据。同一段内存,不同数据有不同的解读方式,这就叫做“视图”(view)
普通数组与 TypedArray 数组的差异主要在以下方面
视图的构造函数可以接受三个参数:
字节序指的是数值在内存中的表示方式。
x86 体系的计算机都采用小端字节序(little endian),相对重要的字节排在后面的内存地址,相对不重要字节排在前面的内存地址
TypedArray 数组内部也采用小端字节序读写数据,或者更准确的说,按照本机操作系统设定的字节序读写数据。
每一种视图的构造函数,都有一个BYTES_PER_ELEMENT属性,表示这种数据类型占据的字节数。
TypedArray 数组的溢出处理规则,简单来说,就是抛弃溢出的位,然后按照视图类型进行解释。
由于视图的构造函数可以指定起始位置和长度,所以在同一段内存之中,可以依次存放不同类型的数据,这叫做“复合视图”。
DataView视图的设计目的,是用来处理网络设备传来的数据,所以大端字节序或小端字节序是可以自行设定的。
DataView通过get和set方法对内存进行读取或写入操作,get和set的最后一个参数通过设置true来转变为小端字节序解读,默认是大端字节序,对于两个或两个字节以上的方法,需要设置字节序
标签:默认 返回 字节 属性 写入 网络 长度 第一个 svi
原文地址:https://www.cnblogs.com/goOtter/p/10266807.html