Node.js v4.2.4 手册 & 文档
目录
Smalloc#
稳定度: 1 - 实验性
smalloc.alloc(length[, receiver][, type])#
length{Number}<= smalloc.kMaxLengthreceiver{Object} 可选,缺省为new Objecttype{Enum} 可选,缺省为Uint8
返回 receiver 及所分配的外部数组数据。如果未传入 receiver 则会创建并返回一个新的 Object。
Buffer 后端为一个只处理外部原始内存的分配的简易分配器所支撑。Smalloc 暴露了该功能。
这可用于创建你自己的类似 Buffer 的类。由于不会设置其它属性,因此使用者需要自行跟踪其它所需信息(比如所分配的长度 length)。
SimpleData.prototype = { /* ... */ };
它只检查 receiver 是否为一个非 Array 的 Object。因此,可以分配外部数组数据的不止纯 Object。
// { [Function allocMe] '0': 0, '1': 0, '2': 0 }
V8 不支持向一个 Array 分配外部数组数据,如果这么做将会抛出异常。
您可以指定您想要的外部数组数据的类型。所有可取的值都已在 smalloc.Types 中列出。使用示例:
// { '0': 0, '1': 0.1, '2': 0.2 }
smalloc.copyOnto(source, sourceStart, dest, destStart, copyLength);#
source分配了外部数组的来源对象sourceStart从这个位置开始拷贝dest分配了外部数组的目标对象destStart拷贝到这个位置copyLength拷贝的长度
从一个外部数组向另一个拷贝内存。所有参数都是必填,否则将会抛出异常。
// { '0': 4, '1': 6, '2': 2, '3': 3 }
copyOnto 会在内部自动检测分配的长度,因此无需对此给出额外的参数。
smalloc.dispose(obj)#
obj对象
释放已使用 smalloc.alloc 分配到一个对象的内存。
// {}
这对于减轻垃圾回收器的负担有所帮助,但开发者务必小心。难以跟踪的应用程序可能会发生奇怪的错误。
// 将导致:
// Error: source has no external array data
dispose() 不支持 Buffer,传入将会抛出异常。
smalloc.kMaxLength#
最大的分配大小。该值同时也适用于 Buffer 的创建。
smalloc.Types#
外部数组类型的可取值,包含:
Int8Uint8Int16Uint16Int32Uint32FloatDoubleUint8Clamped
