Toggle navigation
MeasureThat.net
Create a benchmark
Tools
Feedback
FAQ
Register
Log In
Run results for:
single v double array queue
Go to the benchmark
Embed
Embed Benchmark Result
Run details:
User agent:
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/147.0.0.0 Safari/537.36
Browser:
Chrome 147
Operating system:
Mac OS X 10.15.7
Device Platform:
Desktop
Date tested:
18 days ago
Test name
Executions per second
single
1269.7 Ops/sec
double
466.1 Ops/sec
Script Preparation code:
function createSingleListQueue() { return { queue: [], enqueue(element) { this.queue.push(element) }, dequeue() { return this.queue.shift() }, isEmpty() { return this.queue.length === 0 } } } function createDoubleListQueue() { return { input: [], output: [], enqueue(element) { this.input.push(element) }, dequeue() { if(this.output.length === 0) { this.pivot() } return this.output.pop() }, pivot() { this.output = this.input.reverse() this.input = [] }, isEmpty() { return this.input.length === 0 && this.output.length === 0 } } } var singleQ = createSingleListQueue() var doubleQ = createDoubleListQueue() var queueSize = 100000 for(let i = 0; i < queueSize; i++) { singleQ.enqueue('testString' + i) doubleQ.enqueue('testString' + i) }
Tests:
single
for(let i = 0; i < 100000; i++) { singleQ.dequeue() }
double
for(let i = 0; i < 100000; i++) { doubleQ.dequeue() }