Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/nodejs/node.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBrian White <mscdex@mscdex.net>2017-01-20 06:26:18 +0300
committerMyles Borins <myles.borins@gmail.com>2017-03-09 04:11:16 +0300
commite397e6f94addbb3bfc3e097a61567bb962b54ff3 (patch)
treefa8c26a328495ab20370473c2e24a8e374c4ae17
parent2b528595354e873aca4e25a31a6fb884def7bc4f (diff)
buffer: improve compare() performance
PR-URL: https://github.com/nodejs/node/pull/10927 Reviewed-By: Anna Henningsen <anna@addaleax.net> Reviewed-By: James M Snell <jasnell@gmail.com>
-rw-r--r--benchmark/buffers/buffer-compare-instance-method.js72
-rw-r--r--lib/buffer.js40
2 files changed, 87 insertions, 25 deletions
diff --git a/benchmark/buffers/buffer-compare-instance-method.js b/benchmark/buffers/buffer-compare-instance-method.js
index 0becbeee23a..bb07326f3de 100644
--- a/benchmark/buffers/buffer-compare-instance-method.js
+++ b/benchmark/buffers/buffer-compare-instance-method.js
@@ -4,26 +4,80 @@ const v8 = require('v8');
const bench = common.createBenchmark(main, {
size: [16, 512, 1024, 4096, 16386],
+ args: [1, 2, 3, 4, 5],
millions: [1]
});
function main(conf) {
const iter = (conf.millions >>> 0) * 1e6;
const size = (conf.size >>> 0);
- const b0 = new Buffer(size).fill('a');
- const b1 = new Buffer(size).fill('a');
+ const args = (conf.args >>> 0);
+ const b0 = Buffer.alloc(size, 'a');
+ const b1 = Buffer.alloc(size, 'a');
+ const b0Len = b0.length;
+ const b1Len = b1.length;
+ var i;
b1[size - 1] = 'b'.charCodeAt(0);
// Force optimization before starting the benchmark
- b0.compare(b1);
+ switch (args) {
+ case 2:
+ b0.compare(b1, 0);
+ break;
+ case 3:
+ b0.compare(b1, 0, b1Len);
+ break;
+ case 4:
+ b0.compare(b1, 0, b1Len, 0);
+ break;
+ case 5:
+ b0.compare(b1, 0, b1Len, 0, b0Len);
+ break;
+ default:
+ b0.compare(b1);
+ }
v8.setFlagsFromString('--allow_natives_syntax');
eval('%OptimizeFunctionOnNextCall(b0.compare)');
- b0.compare(b1);
-
- bench.start();
- for (var i = 0; i < iter; i++) {
- b0.compare(b1);
+ switch (args) {
+ case 2:
+ b0.compare(b1, 0);
+ bench.start();
+ for (i = 0; i < iter; i++) {
+ b0.compare(b1, 0);
+ }
+ bench.end(iter / 1e6);
+ break;
+ case 3:
+ b0.compare(b1, 0, b1Len);
+ bench.start();
+ for (i = 0; i < iter; i++) {
+ b0.compare(b1, 0, b1Len);
+ }
+ bench.end(iter / 1e6);
+ break;
+ case 4:
+ b0.compare(b1, 0, b1Len, 0);
+ bench.start();
+ for (i = 0; i < iter; i++) {
+ b0.compare(b1, 0, b1Len, 0);
+ }
+ bench.end(iter / 1e6);
+ break;
+ case 5:
+ b0.compare(b1, 0, b1Len, 0, b0Len);
+ bench.start();
+ for (i = 0; i < iter; i++) {
+ b0.compare(b1, 0, b1Len, 0, b0Len);
+ }
+ bench.end(iter / 1e6);
+ break;
+ default:
+ b0.compare(b1);
+ bench.start();
+ for (i = 0; i < iter; i++) {
+ b0.compare(b1);
+ }
+ bench.end(iter / 1e6);
}
- bench.end(iter / 1e6);
}
diff --git a/lib/buffer.js b/lib/buffer.js
index 49772551643..7c29af3353d 100644
--- a/lib/buffer.js
+++ b/lib/buffer.js
@@ -2,6 +2,7 @@
'use strict';
const binding = process.binding('buffer');
+const { compare: compare_, compareOffset } = binding;
const { isArrayBuffer, isSharedArrayBuffer } = process.binding('util');
const bindingObj = {};
const internalUtil = require('internal/util');
@@ -529,36 +530,43 @@ Buffer.prototype.compare = function compare(target,
if (!(target instanceof Buffer))
throw new TypeError('Argument must be a Buffer');
+ if (arguments.length === 1)
+ return compare_(this, target);
if (start === undefined)
start = 0;
+ else if (start < 0)
+ throw new RangeError('out of range index');
+ else
+ start >>>= 0;
+
if (end === undefined)
end = target.length;
+ else if (end > target.length)
+ throw new RangeError('out of range index');
+ else
+ end >>>= 0;
+
if (thisStart === undefined)
thisStart = 0;
+ else if (thisStart < 0)
+ throw new RangeError('out of range index');
+ else
+ thisStart >>>= 0;
+
if (thisEnd === undefined)
thisEnd = this.length;
-
- if (start < 0 ||
- end > target.length ||
- thisStart < 0 ||
- thisEnd > this.length) {
+ else if (thisEnd > this.length)
throw new RangeError('out of range index');
- }
+ else
+ thisEnd >>>= 0;
- if (thisStart >= thisEnd && start >= end)
- return 0;
if (thisStart >= thisEnd)
- return -1;
- if (start >= end)
+ return (start >= end ? 0 : -1);
+ else if (start >= end)
return 1;
- start >>>= 0;
- end >>>= 0;
- thisStart >>>= 0;
- thisEnd >>>= 0;
-
- return binding.compareOffset(this, target, start, thisStart, end, thisEnd);
+ return compareOffset(this, target, start, thisStart, end, thisEnd);
};