Параметрическое представление
- 1 year ago
- 0
- 0
Промежуточное представление ( intermediate representation ( IR )) — структура данных или код, используемый компилятором или виртуальной машиной для представления исходного кода . Промежуточное представление разработано, чтобы способствовать дальнейшей обработке, такой как оптимизация и трансформация кода. «Хорошее» промежуточное представление должно быть точным — способным представить исходный код без потери информации — и независимым от какого-либо конкретного источника кода или целевого языка. Промежуточное представление может принимать одну из нескольких форм: структура данных расположенная в памяти (in-memory), или специальный кортеж - или стек -подобный код читаемый программой. В последнем случае промежуточное представление также называется промежуточным языком ( intermediate language) .
Канонический пример может быть найден в большинстве современных компиляторов. Например, интерпретатор CPython преобразует линейный удобочитаемый человеком текст, представляющий программу в промежуточную графовую структуру , которая позволяет проанализировать поток данных и перестроить его перед выполнением. Использование такого промежуточного представления позволяет компилирующим системам подобным GNU Compiler Collection и LLVM быть использованными множеством различных исходных языков для генерации кода для множества различных целевых архитектур .
Промежуточный язык — это язык абстрактной машины , спроектированный для помощи в анализе компьютерных программ . Термин происходит от использования языка в компиляторах , где исходный код программы переводится в форму, более подходящую для улучшающих код изменений, прежде чем быть использованным для создания объектного модуля или машинного кода для целевой машины. Дизайн промежуточного языка обычно отличается от машинного кода тремя фундаментальными аспектами:
Популярным форматом промежуточных языков является .
Термин также используется для обозначения языков, используемых в качестве промежуточных некоторыми высокоуровневыми языками программирования , которые не создают объектный модуль или машинный код, а используют только промежуточный язык. Код, созданный на этом промежуточном языке, затем подается компилятору данного языка, который создает финальный объектный модуль или машинный код. Обычно это делается для облегчения процесса оптимизации или увеличения портируемости , благодаря использованию промежуточного языка, для которого есть компиляторы для множества центральных процессоров и операционных систем , таких как C . Языки, используемые для этой цели, ранжируются по сложности между высокоуровневыми языками программирования и низкоуровневыми языками программирования , такими как языки ассемблера .
Хотя он явно не был спроектирован в качестве промежуточного языка, сущность языка C , как абстракции ассемблера и его вездесущность в качестве де-факто в Unix-подобных и других операционных системах сделали его популярным промежуточным языком: Eiffel , , , некоторые диалекты языка программирования Lisp (Lush, ), Haskell ( Glasgow Haskell Compiler ), Nim , Cython , Seed7 , SystemTap , Vala , V и другие используют С в качестве промежуточного языка. Различные варианты языка C были спроектированы для того, чтобы предоставить доступ к функциональности С в качестве портируемого языка ассемблера, включая C-- и .
Любой язык предназначенный для виртуальной или P-код машины может быть рассмотрен как промежуточный язык, например:
Коллекция компиляторов GNU (GCC) использует несколько промежуточных языков для упрощения портативности и кросс-компиляции . Среди этих языков:
GCC поддерживает генерацию следующих промежуточных представлений, в качестве конечной цели:
Инструменты статического анализа часто используют промежуточное представление. Например, radare2 — набор инструментов для анализа двоичных файлов и обратного инжиниринга, использует промежуточные языки ESIL и REIL для анализа двоичных файлов.