beldmit: (Программизм)
[personal profile] beldmit
Как выжать максимум производительности из FizzBuzz на C

Любопытно, хотя я бы остановился гораздо раньше, потому что я считаю, что maintainability в норме ценнее, чем производительность.

Date: 2021-04-06 01:05 pm (UTC)
slobin: (Default)
From: [personal profile] slobin
Н-да? Либо мы играем в слова с постановкой задачи (если "слить результат в /dev/null" считается корректным, то пустая программа даёт тот же самый ответ), либо мы во время компиляции пре-генерим эту семигигабайтную выходную строку (никаких проблем, в современных языках это делается дописыванием одного ключевого слова, const или аналогичного в зависимости от языка). Но я подозреваю уверен, что получившийся монстр будет зачитываться в память дольше.

Собственно, даже если и бинарник, и результаты будут изначально в памяти (на ram-диске), то всё равно тупое копирование длинной строки байтов -- не самый быстрый способ получить выходную строку. Оптимизированные "на скорость" (а не "на объём") алгоритмы сжатия (ну то есть, разжатия) заполняют её быстрее, за счёт меньшего количества чтений из памяти исходной строки (собственно алгоритм оказывается дешевле). А результат fizzbuzz, очевидно, хорошо сжимается.

Кому тут ещё санитары нужны?

... Press any key... No, no, no, NOT THAT ONE! ...

Profile

beldmit: (Default)
Dmitry Belyavskiy

May 2025

S M T W T F S
    123
45678910
11121314151617
181920212223 24
25262728293031

Most Popular Tags

Page Summary

Style Credit

Expand Cut Tags

No cut tags
Page generated Jun. 28th, 2025 03:19 am
Powered by Dreamwidth Studios