jsPerf.app is an online JavaScript performance benchmark test runner & jsperf.com mirror. It is a complete rewrite in homage to the once excellent jsperf.com now with hopefully a more modern & maintainable codebase.
jsperf.com URLs are mirrored at the same path, e.g:
https://jsperf.com/negative-modulo/2
Can be accessed at:
https://jsperf.app/negative-modulo/2
Testing string concatenation methods in straight code and abstracted in a StringBuilder
<script>
var CONST = {
STR_PART: 'Hello Diggity Dog more more more more more more more more more more more more more more more more more more more',
ITERATIONS: 30
};
function StringBuilderConcat() {
this._str = "";
}
StringBuilderConcat.prototype.append = function (str) {
this._str += str;
}
StringBuilderConcat.prototype.toString = function () {
return this._str;
}
function StringBuilderArrayPush() {
this._array = [];
}
StringBuilderArrayPush.prototype.append = function (str) {
this._array.push(str);
}
StringBuilderArrayPush.prototype.toString = function () {
return this._array.join('');
}
function StringBuilderArrayIndex() {
this._array = [];
this._index = 0;
}
StringBuilderArrayIndex.prototype.append = function (str) {
this._array[this._index] = str;
this._index++;
}
StringBuilderArrayIndex.prototype.toString = function () {
return this._array.join('');
}
function StringBuilderHack(){
this._a=[];
this.append=Array.prototype.push.bind(this._a);
}
StringBuilderHack.prototype.toString=function(){
var a=this._a, out=a[0];
for (var i=1, l=a.length; i < l; i ++) {
out+=a[i];
}
return out;
}
function StringBuilderHack2(){
this._a=[];
this.append=Array.prototype.push.bind(this._a);
this.toString=Array.prototype.join.bind(this._a, '');
}
var preparedArray = [];
for (var i=0; i < CONST.ITERATIONS; i ++) {
preparedArray[preparedArray.length] = String.fromCharCode(i);
}
Array.prototype.joinAsString=function(){
var out='';
for (var i=0, l=this.length; i < l; i ++) {
out+=this[i];
}
return out;
}
Array.prototype.join2=function(s){
if(!this.length){
return '';
}
var out=this[0];
for (var i=1, l=this.length; i < l; i ++) {
out+=s+this[i];
}
return out;
}
</script>
Ready to run.
Test | Ops/sec | |
---|---|---|
Array index - No Abstraction |
| ready |
Array push - No abstraction |
| ready |
Straight String Concat - No abstraction |
| ready |
StringBuilder - Array index |
| ready |
StringBuilder - Array push |
| ready |
StringBuilder - string concat |
| ready |
StringBuilder - Hack Array |
| ready |
StringBuilder - Hack Array2 |
| ready |
Fair native + |
| ready |
Fair array.join |
| ready |
Fair join2 |
| ready |
Fair joinAsString |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.