I'll do some work on a line separated string. Which one will be faster, to split the text via String.split first and then walk on the resultant array or directly walk the whole text via a reg exp and construct the final array on the way?
3 Answers
Well, the best way to get your answer is to just take 2 minutes and write a loop that does it both ways a thousand times and check firebug to see which one is faster ;)
I've had to optimize a lot of string munging while working on MXHR and in my experience, plain String methods are significantly faster than RegExps in current browsers. Use RegExps on the shortest Strings possible and do everything you possibly can with String methods.
For example, I use this little number in my current code:
var mime = mimeAndPayload.shift().split('Content-Type:', 2)[1].split(";", 1)[0].replace(' ', '');
It's ugly as hell, but believe it or not it's significantly faster than the equivalent RegExp under high load.
6 Comments
performance object performs way better than the Date object for timing. Still gives some bogus data (like zero when it obviously wasn't zero) so you can filter those out. I have found this to be the easiest way to narrow down speeds of specific implementation choices.While this is 2½ years late, hopefully this helps shed some light on the matter for any future viewers: https://jsperf.app/split-join-vs-regex-replace (Includes benchmarks results for multiple browsers, as well the functional benchmark code itself)
2 Comments
I expect that using split() will be much faster. It depends upon many specifics, number of lines vs. length, complexity of regex, etc.
5 Comments
.split() to be faster than regex.