Jump to content

Инвариантное программирование

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

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

Идея разработки программы вместе с ее доказательством возникла у Э. У. Дейкстры . Написание инвариантов перед операторами программы в различных формах рассматривалось М. ​​Х. ван Эмденом, Дж. К. Рейнольдсом и Р. Дж. Бэком .

См. также [ править ]

Примечания [ править ]

  1. ^ Назад, Ральф-Йохан: Программирование на основе инвариантов: базовый подход и опыт преподавания , Формальные аспекты вычислений, 14 февраля 2008 г., ISSN 0934-5043 (для печати) 1433-299X (онлайн)
Arc.Ask3.Ru: конец переведенного документа.
Arc.Ask3.Ru
Номер скриншота №: a91828bef53620743d780eebcaa767eb__1598870700
URL1:https://arc.ask3.ru/arc/aa/a9/eb/a91828bef53620743d780eebcaa767eb.html
Заголовок, (Title) документа по адресу, URL1:
Invariant-based programming - Wikipedia
Данный printscreen веб страницы (снимок веб страницы, скриншот веб страницы), визуально-программная копия документа расположенного по адресу URL1 и сохраненная в файл, имеет: квалифицированную, усовершенствованную (подтверждены: метки времени, валидность сертификата), открепленную ЭЦП (приложена к данному файлу), что может быть использовано для подтверждения содержания и факта существования документа в этот момент времени. Права на данный скриншот принадлежат администрации Ask3.ru, использование в качестве доказательства только с письменного разрешения правообладателя скриншота. Администрация Ask3.ru не несет ответственности за информацию размещенную на данном скриншоте. Права на прочие зарегистрированные элементы любого права, изображенные на снимках принадлежат их владельцам. Качество перевода предоставляется как есть. Любые претензии, иски не могут быть предъявлены. Если вы не согласны с любым пунктом перечисленным выше, вы не можете использовать данный сайт и информация размещенную на нем (сайте/странице), немедленно покиньте данный сайт. В случае нарушения любого пункта перечисленного выше, штраф 55! (Пятьдесят пять факториал, Денежную единицу (имеющую самостоятельную стоимость) можете выбрать самостоятельно, выплаичвается товарами в течение 7 дней с момента нарушения.)