Оптимизација цикличних операција у JavaScript
Чак и лака операција, поновљена више пута у циклусу, може утрошити много ресурса.
Хајде да погледамо пример. Претпоставимо да имамо неки низ:
let arr = [1, 2, 3, 4, 5, 6];
Хајде да нађемо просек елемената овог низа. За то треба наћи суму елемената и поделити је са њиховим бројем. Претпоставимо да је неки програмер већ решио овај задатак на следећи начин:
let avg = 0;
for (let elem of arr) {
avg += elem / arr.length;
}
console.log(avg);
Хајде да размотримо проблеме оваквог решења. Технички код ради исправно и даје тачан резултат. Ствар је у томе што је математички исправно како поделити целу суму са бројем, тако и поделити сваки сабирак појединачно са бројем.
Међутим, настаје други проблем. Ствар је у томе што ћемо извршавати дељење онолико пута колико има елемената у нашем низу. И испоставља се да радимо велики број непотребних операција, јер бисмо дељење могли да извршимо на крају - само једном, поделивши целу пронађену суму.
Хајде да оптимизујемо наш код:
let sum = 0;
for (let elem of arr) {
sum += elem;
}
let avg = sum / arr.length;
console.log(avg);
Оптимизујте следећи код:
for (let i = 1900; i <= 2100; i++) {
let curr = new Date;
let date = new Date(i, curr.getMonth(), curr.getDate());
if (curr.getDay() === date.getDay()) {
console.log(date);
}
}
Оптимизујте следећи код:
let obj = {a: 10, b: 20, c: 30, d: 40, e: 50};
let sum = 0;
for (let key in obj) {
if (String(obj[key])[0] === '1' || String(obj[key])[0] === '2') {
sum += obj[key];
}
}
console.log(sum);