Jump to content

Трансформация программы

Преобразование программы это любая операция, которая берет компьютерную программу и создает другую программу. Во многих случаях преобразованная программа должна быть семантически эквивалентна оригиналу относительно определенной формальной семантики , и в меньшем количестве случаев преобразования приводят к созданию программ, которые семантически отличаются от оригинала предсказуемым образом. [1]

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

Практическим требованием к системам преобразования исходного кода является способность эффективно обрабатывать программы, написанные на языке программирования . Обычно это требует интеграции полного внешнего интерфейса для интересующего языка программирования, включая анализ исходного кода , построение внутренних представлений программы о структурах кода, определение значения программных символов, полезный статический анализ и восстановление допустимого исходного кода из преобразованных представлений программы. . Проблема создания и интеграции адекватных интерфейсов для обычных языков ( Java , C++ , PHP и т. д.) может представлять собой такую ​​же сложность, как и построение самой системы преобразования программ из-за сложности таких языков. Чтобы быть широко полезной, система преобразования должна поддерживать множество целевых языков программирования и предоставлять некоторые средства определения таких внешних интерфейсов.

Обобщением семантической эквивалентности является понятие уточнения программы : одна программа является уточнением другой, если она завершается во всех начальных состояниях, в которых завершается исходная программа, и для каждого такого состояния она гарантированно завершается в возможном конечном состоянии для оригинальная программа. Другими словами, усовершенствованная программа более определена и более детерминирована, чем исходная программа. Если две программы являются усовершенствованиями друг друга, то они эквивалентны. [ нужны разъяснения ]

См. также

[ редактировать ]
  1. ^ Уорд, Мартин (1989). Доказательство усовершенствований и преобразований программы (докторская диссертация). Оксфордский университет. {{cite book}}: CS1 maint: отсутствует местоположение издателя ( ссылка )
[ редактировать ]


Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: 3762682f1a5b4acc231deb5387b3c20c__1715209920
URL1:https://arc.ask3.ru/arc/aa/37/0c/3762682f1a5b4acc231deb5387b3c20c.html
Заголовок, (Title) документа по адресу, URL1:
Program transformation - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)