От интерпретированного к нативному коду: поддержка компилятора «динамических» языков - PullRequest
3 голосов
/ 19 мая 2010

Во-первых, я знаю, что динамические языки - это термин, используемый в основном поставщиком; Я использую его просто для того, чтобы иметь контейнерное слово для включения таких языков, как Perl (мой любимый), Python, Tcl, Ruby, PHP и так далее. Они интерпретируются, но мне интересно здесь обратиться к языкам, обладающим сильной способностью поддерживать эффективность работы программиста и поддержку типичных конструкций современных интерпретируемых языков

Мой вопрос: есть ли динамические языки, которые можно эффективно компилировать в собственном исполняемом коде - обычно для платформ Windows? Какие? Может быть, использовать какие-то специальные инструменты третьей части? Я не говорю об огромных исполняемых файлах, несущих с собой полный интерпретатор, или о некоторых похожих трюках, или о каком-то умном модуле, способном включать собственные зависимости или некоторые необходимые модули, но о честном, прямом, стандартном, надежном исполняемом коде.

Если нет, то есть какая-то техническая причина, ограничивающая доступность такой лучшей в мире функции?

Спасибо!

Daniel

Ответы [ 3 ]

4 голосов
/ 19 мая 2010

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

В Windows большая часть времени выполнения уже установлена, поэтому вам не нужно его отправлять. Вы думаете, ваша программа небольшая, но быстрый просмотр отображений виртуальной памяти скажет вам, что даже небольшая программа типа "hello-world", написанная на C, имеет размер в пару мегабайт.

Вот как много полезного времени выполнения.

Если вы действительно хотите, чтобы размер вашего корабля был небольшим, ваш единственный выбор - использовать уже имеющиеся среды выполнения, а , что означает C / C ++ и (недавно) точка-сеть.

Если вы действительно не можете проглотить время выполнения, Forth настолько мал, насколько это возможно.

Лучшими, наиболее агрессивными динамическими языками с лучшими компиляторами для Windows являются коммерческие Lisps. Они производят много вставок и сокращений при создании исполняемых файлов, так что в итоге вы отправляете только то, что используете. Они по-прежнему в 1,5–5 раз больше, чем программы на C / C ++.

Что касается языков, которые вы знаете: Perl настолько толстый, насколько они получают. ActiveState имеет perlapp , который, я уверен, вы уже знаете, но вы уволены из-за его размера. Пересмотрите его, если можете.

Теперь, чтобы ответить на ваш вопрос (есть) есть какая-то техническая причина, ограничивающая доступность такой лучшей в мире функции? : Да .

Perl не может быть подвергнут статическому анализу ( proof ), что означает, что компилятор Perl не может сказать, что можно отбросить. Это означает, что каждая часть времени выполнения Perl должна быть доступна для вашей программы, потому что у вашей программы нет возможности указать, какие части могут быть отброшены.

Это означает, что означает, что получение меньшего исполняемого файла равносильно получению меньшего времени выполнения, и вам должно быть удобно, если разработчики Perl знают, как уменьшить время выполнения Perl, не отказываясь от каких-либо функций, они ' Я бы, наверное, сделал это.

Если вы хотите писать в строгом подмножестве Python или PHP, эти языки могут быть проанализированы. Shed Skin и HipHop-php довольно хороши, но они все еще довольно велики, и они не поддерживают все функции Pythons и PHP, что означает, что некоторые модули просто не будут Работа. Насколько мне известно, никто не реализовал сокращение для любого из этих языков (основное внимание в этих компиляторах уделяется повышению их невысокой производительности), и может пройти еще десятилетие или даже больше, прежде чем кто-то потрудится, однако это все равно будет ограничения, которые вы должны принять при выполнении подобных действий.

2 голосов
/ 19 мая 2010

Проект PyPy делает то, что вы описываете для довольно полного подмножества Python.

В общем случае это очень сложная проблема, решаемая в основном из-за самих атрибутов.которые делают эти языки «динамическими»: позднее связывание, слабо типизированные переменные, структуры данных и контейнеры, eval средства, нечеткое разделение между программированием и метапрограммированием и т. д. Но в него вкладывается много усилий, таких какв качестве проектов JIT-компилятора JavaScript перечислено здесь .

1 голос
/ 19 мая 2010

Shed Skin - это экспериментальный (и ограниченный) компилятор Python-to-C ++, который может делать то, что вы описываете. Как указывает Marcelo выше с PyPy, существуют ограничения на то, что вы можете компилировать с помощью Shed Skin, но если вы готовы принять ограничения, вы можете добиться значительного ускорения.

...