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
const generateState = (size) => {
return new Array(size).fill().map((e, i) => ({ id: i, text: `text ${i}` }));
}
const state = generateState(50);
const stateToMerge = generateState(70);
const getNewStateForEach = (state, messages) => {
const messagesToMerge = [];
messages.forEach((message) => {
const alreadyInState = state.find((messageInState) => messageInState.id === message.id);
if (!alreadyInState) {
messagesToMerge.push(message);
}
});
return [...messagesToMerge, ...state];
}
const getNewStateReduce = (state, messages) => {
const messagesToMerge = messages.reduce((acc, message) => {
const alreadyInState = acc.find((messageInState) => messageInState.id === message.id);
if (!alreadyInState) {
acc.push(message);
}
return acc
}, state);
return [...messagesToMerge, ...state];
}
const getNewStateSet = (state, messages) => {
const idsInState = new Set(state.map((message) => message.id));
const messagesNotInState = messages.filter((message) => !idsInState.has(message.id));
return [...messagesNotInState, ...state];
}
Ready to run.
Test | Ops/sec | |
---|---|---|
Using forEach |
| ready |
Using reduce |
| ready |
Using Set |
| ready |
You can edit these tests or add more tests to this page by appending /edit to the URL.