node/lib/freelist.js

27 lines
670 B
JavaScript
Raw Normal View History

'use strict';
// This is a free list to avoid creating so many of the same object.
exports.FreeList = function(name, max, constructor) {
this.name = name;
this.constructor = constructor;
this.max = max;
this.list = [];
2010-10-07 11:05:23 +08:00
};
2010-12-02 09:43:30 +08:00
exports.FreeList.prototype.alloc = function() {
//debug("alloc " + this.name + " " + this.list.length);
2010-12-02 09:43:30 +08:00
return this.list.length ? this.list.shift() :
this.constructor.apply(this, arguments);
};
2010-12-02 09:43:30 +08:00
exports.FreeList.prototype.free = function(obj) {
//debug("free " + this.name + " " + this.list.length);
if (this.list.length < this.max) {
this.list.push(obj);
return true;
}
return false;
};