Após a pergunta Estendendo o desempenho do String.prototype , estou realmente intrigado, porque apenas adicionar "use strict"
um String.prototype
método melhorou o desempenho 10 vezes. A explicação de Bergi é curta e não me explica. Por que existe uma diferença tão dramática entre dois métodos quase idênticos, que apenas diferem no "use strict"
topo? Você pode explicar com mais detalhes e com a teoria por trás disso?
String.prototype.count = function(char) {
var n = 0;
for (var i = 0; i < this.length; i++)
if (this[i] == char) n++;
return n;
};
String.prototype.count_strict = function(char) {
"use strict";
var n = 0;
for (var i = 0; i < this.length; i++)
if (this[i] == char) n++;
return n;
};
// Here is how I measued speed, using Node.js 6.1.0
var STR = '0110101110010110100111010011101010101111110001010110010101011101101010101010111111000';
var REP = 1e4;
console.time('proto');
for (var i = 0; i < REP; i++) STR.count('1');
console.timeEnd('proto');
console.time('proto-strict');
for (var i = 0; i < REP; i++) STR.count_strict('1');
console.timeEnd('proto-strict');
Resultado:
proto: 101 ms
proto-strict: 7.5 ms
this[i] === char
num ambiente de DOM e o resultado é o mesmo
count
função, o this
parâmetro deve ser convertido em um objeto de string em vez de em um literal de string, enquanto no modo estrito não é necessário para operar corretamente. Por que esse é o caso está além de mim, estou muito interessado na resposta.
this
, mas, no modo estrito, pula essa etapa, para que você obtenha a string primitiva ou o que for fornecido this
.
"use strict";
todos os lugares meninos! Goooold
this[i] === char
e ver se obtém a mesma diferença?