The Wayback Machine - https://web.archive.org/web/20221205115821/https://github.com/HowProgrammingWorks/Benchmark
Skip to content

HowProgrammingWorks/Benchmark

master
Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?
Code

Latest commit

 

Git stats

Files

Permalink
Failed to load latest commit information.
Type
Name
Latest commit message
Commit time
 
 
 
 
 
 
 
 

Измерение производительности кода и оптимизация

===============

Измерение производительности кода и оптимизация

Оптимизация

  • Объекты одинаковой структуры
  • Функции одинаковой формы (мономорфные)
  • Массивы одинаковых типов

Замер скорости

  • Желательно проверять крупные алгоритмы или целые блоки
  • Одинаковые условия исполнения для каждой итерации теста
  • Единица оптимизации - функция, оборачиваем тестируемый код в функцию
  • Сохраняем результаты (вводим оптимизатор в заблуждение)
  • Прогрев кода перед тестом (дождаться стабилизации)
  • Может получиться инлайнинг функций (можно проверить руками)
  • Чтоб не инлайнило, например (можно добавить try {})
  • Принимаем во внимание, что константы подставляются в выражения
  • Выражения могут быть предварительно вычислены (не на каждой итерации)
  • Вынесение инвариантов цикла (в цикле остается только то, на что влияет цикл)
  • Мертвый код (который мог бы быть выброшен оптимизатором)
  • Внетренние функции v8 --allow-natives-syntax
  • Отключение автоматического gc --nouse-idle-notification
  • Ручной gc --expose-gc
  • Выделение больше памяти --max_old_space_size=2048