lib: freelist: use .pop() for allocation
Array#pop() is known to be faster than Array#shift(). To be exact, it's O(1) vs. O(n). In this case there's no difference from which side of the "pool" array the object is retrieved, so .pop() should be preferred. PR-URL: https://github.com/nodejs/node/pull/2174 Reviewed-By: mscdex - Brian White <mscdex@mscdex.net> Reviewed-By: jasnell - James M Snell <jasnell@gmail.com> Reviewed-By: ofrobots - Ali Ijaz Sheikh <ofrobots@google.com>
This commit is contained in:
parent
6361c049a9
commit
c647e87504
38
benchmark/misc/freelist.js
Normal file
38
benchmark/misc/freelist.js
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var common = require('../common.js');
|
||||||
|
var FreeList = require('internal/freelist').FreeList;
|
||||||
|
|
||||||
|
var bench = common.createBenchmark(main, {
|
||||||
|
n: [100000]
|
||||||
|
});
|
||||||
|
|
||||||
|
function main(conf) {
|
||||||
|
var n = conf.n;
|
||||||
|
var poolSize = 1000;
|
||||||
|
var list = new FreeList('test', poolSize, Object);
|
||||||
|
var i;
|
||||||
|
var j;
|
||||||
|
var used = [];
|
||||||
|
|
||||||
|
// First, alloc `poolSize` items
|
||||||
|
for (j = 0; j < poolSize; j++) {
|
||||||
|
used.push(list.alloc());
|
||||||
|
}
|
||||||
|
|
||||||
|
bench.start();
|
||||||
|
|
||||||
|
for (i = 0; i < n; i++){
|
||||||
|
// Return all the items to the pool
|
||||||
|
for (j = 0; j < poolSize; j++) {
|
||||||
|
list.free(used[j]);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Re-alloc from pool
|
||||||
|
for (j = 0; j < poolSize; j++) {
|
||||||
|
list.alloc();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bench.end(n);
|
||||||
|
}
|
@ -10,7 +10,7 @@ exports.FreeList = function(name, max, constructor) {
|
|||||||
|
|
||||||
|
|
||||||
exports.FreeList.prototype.alloc = function() {
|
exports.FreeList.prototype.alloc = function() {
|
||||||
return this.list.length ? this.list.shift() :
|
return this.list.length ? this.list.pop() :
|
||||||
this.constructor.apply(this, arguments);
|
this.constructor.apply(this, arguments);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -27,6 +27,6 @@ assert.strictEqual(flist1.free('test4'), false);
|
|||||||
assert.strictEqual(flist1.free('test5'), false);
|
assert.strictEqual(flist1.free('test5'), false);
|
||||||
|
|
||||||
// At this point 'alloc' should just return the stored values
|
// At this point 'alloc' should just return the stored values
|
||||||
assert.strictEqual(flist1.alloc(), 'test1');
|
|
||||||
assert.strictEqual(flist1.alloc(), 'test2');
|
|
||||||
assert.strictEqual(flist1.alloc(), 'test3');
|
assert.strictEqual(flist1.alloc(), 'test3');
|
||||||
|
assert.strictEqual(flist1.alloc(), 'test2');
|
||||||
|
assert.strictEqual(flist1.alloc(), 'test1');
|
||||||
|
Loading…
x
Reference in New Issue
Block a user