Node.js Smalloc

Smalloc

稳定性: 1 - 试验

类: smalloc

表示能够通过简单的内存分配器(处理扩展原始内存的分配)支持的缓存,可供Smalloc使用的函数如下所示:

smalloc.alloc(length, receiver)

  • length {Number} <= smalloc.kMaxLength

此函数的作用为返回包含分配的外部数组数据的receiver对象。如果没有传入receiver,则将会创建并返回一个新的对象。

这可以用来创建你自己的类似buffer的类。不会设置其他属性,因此使用者需要跟踪其他所需信息(比如分配的长度)。

function SimpleData(n) { this.length = n; smalloc.alloc(this.length, this } SimpleData.prototype = { /* ... */ };

仅检查receiver是否是非数组的对象。因此,可以分配扩展数据数据,不仅是普通对象。

function allocMe() { } smalloc.alloc(3, allocMe // { [Function allocMe] '0': 0, '1': 0, '2': 0 }

v8不支持给数组分配扩展数组对象,如果这么做,将会抛出。

你可以指定外部数组数据的类型,在smalloc.Types列出了可供使用的外部数组数据的类型,例如:

var doubleArr = smalloc.alloc(3, smalloc.Types.Double for (var i = 0; i < 3; i++) doubleArr = i / 10; // { '0': 0, '1': 0.1, '2': 0.2 }

使用Object.freeze,Object.sealObject.preventExtensions不能冻结、封锁、阻止对象的使用扩展数据扩展。

smalloc.copyOnto(source, sourceStart, dest, destStart, copyLength

  • source {Object} 分配了外部数组的对象

将内存从一个外部数组分配复制到另一个数组中,任何参数都是可选的,否则会抛出异常。

var a = smalloc.alloc(4 var b = smalloc.alloc(4 for (var i = 0; i < 4; i++) { a[i] = i; b[i] = i * 2; } // { '0': 0, '1': 1, '2': 2, '3': 3 } // { '0': 0, '1': 2, '2': 4, '3': 6 } smalloc.copyOnto(b, 2, a, 0, 2 // { '0': 4, '1': 6, '2': 2, '3': 3 }

copyOnto将自动检测内部分配的长度,因此不需要设置任何附加参数。

smalloc.dispose(obj)

  • obj Object

释放通过smalloc.alloc给对象分配的内存。

var a = {}; smalloc.alloc(3, a // { '0': 0, '1': 0, '2': 0 } smalloc.dispose(a // {}

这对于减轻垃圾回收器的负担是有效的,但是在开发的时候还是要小心,程序里可能会出现难以跟踪的错误。

var a = smalloc.alloc(4 var b = smalloc.alloc(4 // perform this somewhere along the line smalloc.dispose(b // now trying to copy some data out smalloc.copyOnto(b, 2, a, 0, 2 // now results in: // RangeError: copy_length > source_length

调用dispose(),对象依旧拥有外部数据,例如smalloc.hasExternalData()会返回truedispose()不支持缓存,如果传入将会抛出。

smalloc.hasExternalData(obj)

  • obj {Object}

如果obj拥有外部分配的内存,返回true

smalloc.kMaxLength

可分配的最大数量。则同样适用于缓冲区的创建。

smalloc.Types

外部数组的类型,包含:

  • Int8