Цитата:
Я приводил пример - суммирование 10 000 000 элементов массива занимает 20 мс. https://javascript.ru/forum/530002-post6.html |
Цитата:
|
Цитата:
Правда, в его случае используется map, то есть лишние расходы, но тем не менее. |
Я даже не представляю, что там может быть долго?
Вот тест. 100 раз выполняется просмотр массива из 10 000 элементов для поиска одинаковых <!DOCTYPE html> <html> <head> <meta http-equiv="Content-type" content="text/html; charset=utf-8" lang="ru"> <meta name="viewport" content="width=device-width, initial-scale=1.0" > <title>TEST SPEED</title> <style> </style> </head> <body id="body" > <script> const r = (m) => Math.random()*m | 0; const colors = ['red', 'orange', 'yellow', 'green', 'cyan', 'blue', 'violet']; const ar = []; const l = 10_000; for (let i = 0; i < l; i++) ar.push ({color: colors[r(colors.length)], data: r(10)}); const nc = 100; let findsame = (a, key) => { const res = []; for (let i=0; i<a.length; i++) { if (key.color === a[i].color && key.data === a[i].data) res.push(i); } return res } const t0 = performance.now(); for (ic = 0; ic < nc; ic++) { const key = {color: colors[r(colors.length)], data: r(10)}; const res = findsame(ar, key); // console.log(ic, res); } const dt = (performance.now()-t0)/1000; alert(` Time: ${dt} seconds`); </script> </body> </html> У меня получается 6-8 мс на ноуте (довольно мощный) и 50-60 мс на не слишком навороченном смартфоне. |
Цитата:
|
Цитата:
Ничего не помогает. Когда перехожу в режим редактирования там < стоит. Ну меняю < на <. Толку нет. Но ошибок не выдает и при раскомментаренном console.log(ic, res); результаты выдает, хотя время, конечно, другое. |
Нифига себе, происки империалистов, сейчас попробуем. )
var a = b < c; const r = (m) => Math.random()*m | 0; const colors = ['red', 'orange', 'yellow', 'green', 'cyan', 'blue', 'violet']; const ar = []; const l = 10_000; for (let i = 0; i < l; i++) ar.push ({color: colors[r(colors.length)], data: r(10)}); const nc = 100; let findsame = (a, key) => { const res = []; for (let i=0; i<a.length; i++) { if (key.color === a[i].color && key.data === a[i].data) res.push(i); } return res } const t0 = performance.now(); for (ic = 0; ic < nc; ic++) { const key = {color: colors[r(colors.length)], data: r(10)}; const res = findsame(ar, key); // console.log(ic, res); } const dt = (performance.now()-t0)/1000; alert(` Time: ${dt} seconds`); Нет проблем, скопировал - текст в коде, заменил - все норма. У вас клавиша < на клавиатуре решила, что так лучше будет :) |
Цитата:
Да хрен с ней лишь бы работало. Цитата:
|
Цитата:
|
Часовой пояс GMT +3, время: 08:46. |