Мысли о десятилетии развития MoarVM — виртуальной машины языка Raku

Мысли о десятилетии развития  MoarVM - виртуальной машины языка Raku

19 октября состоится выступление Джонатана Уортингтона, основного разработчика виртуальной машины MoarVM для языка программирования Raku.

MoarVM явилась результатом юношеского максимализма. Я участвовал в разработке компилятора Raku (на тот момент Perl 6), и рассматривая виртуальную машину Parrot, на которую мы ориентировались тогда, видя все её проблемы (особенно в части производительности и многопоточности), думал:, а не попробовать ли создать что-то получше? Благо на тот момент свободного времени было предостаточно… В течение нескольких лет, с помощью десятков добровольцев, удалось полностью заменить Parrot и сделать MoarVM предпочтительной средой исполнения. [прим. пер. существует официальный набор тестов для языка программирования Raku. Любая реализация проходящая эти тесты может называться Raku. В предыдущем предложении имеется ввиду, что предпочтительной виртуальной машиной для «эталонной» реализации считается MoarVM].

Почти десять лет прошло с момента начала работы над MoarVM.

Простой интерпретатор байт-кода, реализованный на первых порах, неустанно обрастал профессиональным инструментарием: типо-ориентированными оптимизациями, деоптимизацией, подстановками (inlining), заменами на стеке, динамической компиляцией (JIT), статическим анализом времени жизни (области достижимости) объекта (escape analysis).

За перечисленными улучшениями последовали новые: были переработаны некоторые горячие операции, ранее реализованные в целях повышения производительности в виде примитивов уровня виртуальной машины, и обернувшиеся бутылочным горлышком, будучи невидимыми для механизмов оптимизации.

Совсем недавно появился новый механизм диспетчеризации, позволивший заменить ряд алгоритмов для обработки особых случаев (например, методов и функций с множественной диспетчеризацией) на единый стандартный способ. Хотя многоязычность никогда не предполагалась при разработке MoarVM, в процессе улучшения производительности и попытке справиться с её растущей сложностью, проект пришел в состояние достаточно сильного абстрагирования от языка программирования Raku.

В выступлении будет сделан обзор пройденного в ходе работы над MoarVM пути, освещены наиболее интересные вызовы, извлечённые уроки и компромиссы на которые пришлось пойти.

Будет описана концепция возобновляемой диспетчеризации, позволившая ускорить некоторые неподдающиеся ранее оптимизации участки. Так же будет рассказано и о проблемах которые повлекли указанные подходы.

>>> Подробности

Источник: pcnews.ru



Добавить комментарий