JavaScript String Equality Performance Comparison
Solution 1:
Most probably Javascript is doing string interning (Do common JavaScript implementations use string interning?) according to a person that is in ECMAScript committee. I thought that then === would be O(1) but based on performance test of the original poster it is O(n) as doubling the string doubles the time for the equality.. That is really sad that string interning is not used they way it should be.
Update: JSPerf
The orginal poster claims should be backed up for O(N) complexity From http://jsperf.com/eqaulity-is-constant-time It seems that even if I have 16x bigger string the time doesn't change more than 1-2%
So please reconsider those things that I have striked-through and your down votes
In other words:
when you do
var str1 = "stringwithmillionchars"; //stored in address 51242
var str2 = "stringwithmillionchars"; //stored in address 12313
the "stringwithmillionchars" will be stored once let's say in address 201012 of memory and both str1 and str2 will be "pointing in this address 201012. This address could be determined with some kind of hashing to map to specific locations in memory.
So when doing
"stringwithmillionchars"==="stringwithmillionchars"
would look like
getContentOfAddress(51242)===getContentOfAddress(12313)
or 201012 === 201012
which takes O(1)/constant time
The for loop in your example (equals2()) has O(N) time, where N the length of both strings. That is because it has to do N comparisons between each pair of characters and N comparisons between i and str.length.
Note: the address numbers were chosen randomly for illustration purposes..
Important: Based on performance comparisons from my question(Why Javascript ===/== string equality sometimes has constant time complexity and some times has linear time complexity) interning happens only when the strings are assigned directly with quotes otherwise the comparison will take linear time instead of constant because char-to-char comparison happens.
Solution 2:
The first function is faster because it doesn't have to check if i < a.length
one million times, and perform an increment operation on i
one million times.
Solution 3:
You can do something like the following to make your equals2
function twice faster:
function equals2(a, b) {
if (a.length !== b.length) {
return false;
}
for (var i = 0; i < a.length/2; ++i) {
if (a[i] !== b[i] || a[a.length-i-1] !== b[b.length-i-1]) {
return false;
}
}
return true;
}
Solution 4:
The first does the same things. If the strings are different lengths, it will return false. Then it checks to see if the characters are the same at the same indices. However, it is implemented at the JS implementation level, so it is running as fast as C, C++, Java or whatever language the JavaScript implementation is written in.
Post a Comment for "JavaScript String Equality Performance Comparison"