ОСНОВНОЕ ОБНОВЛЕНИЕ.
Мысль о том, что еще не выпущена в Chrome, выпущена новая Ignition + Turbofan engine для Chrome Canary 59, решила проблему. Тест показывает идентичные времена для let
и var
объявленных переменных цикла.
Оригинальный (теперь немой) вопрос.
При использовании let
в цикле for
в Chrome он работает очень медленно, по сравнению с перемещением переменной непосредственно за пределы области цикла.
for(let i = 0; i < 1e6; i ++);
занимает в два раза длиннее
{ let i; for(i = 0; i < 1e6; i ++);}
Что происходит?
Фрагмент демонстрирует разницу и влияет только на Chrome, и так было до тех пор, пока я помню Chrome, поддерживающий let
.
var times = [0,0]; // hold total times
var count = 0; // number of tests
function test(){
var start = performance.now();
for(let i = 0; i < 1e6; i += 1){};
times[0] += performance.now()-start;
setTimeout(test1,10)
}
function test1(){
// this function is twice as quick as test on chrome
var start = performance.now();
{let i ; for(i = 0; i < 1e6; i += 1);}
times[1] += performance.now()-start;
setTimeout(test2,10)
}
// display results
function test2(){
var tot =times[0]+times[1];
time.textContent = tot.toFixed(3) + "ms";
time1.textContent = ((times[0]/tot)*100).toFixed(2) + "% " + times[0].toFixed(3) + "ms";
time2.textContent = ((times[1]/tot)*100).toFixed(2) + "% " + times[1].toFixed(3) + "ms";
if(count++ < 1000){;
setTimeout(test,10);
}
}
var div = document.createElement("div");
var div1 = document.createElement("div");
var div2 = document.createElement("div");
var time = document.createElement("span");
var time1 = document.createElement("span");
var time2 = document.createElement("span");
div.textContent = "Total execution time : "
div1.textContent = "Test 1 : "
div2.textContent = "Test 2 : "
div.appendChild(time);
div1.appendChild(time1);
div2.appendChild(time2);
document.body.appendChild(div);
document.body.appendChild(div1);
document.body.appendChild(div2);
test2()