Технологии, основанные на логике разделения, позволяют разрабатывать системы для верификации крупных программных проектов[7].
Предпосылки создания
Логика Хоара имеет ряд ограничений, работая только с изменяемыми переменными и не поддерживая процедуры или код первого класса. Тем не менее, самое большое ограничение — это отсутствие поддержки указателей, что наиболее актуально для спецификации императивных программ. В случае использования указателей и кучи от изменяемых переменных можно отказаться, присваивая локальным переменным значение-указатель лишь один раз[8].
В 2000—2002 годах Джон Рейнольдс и Питер О’Хирн придумали расширение логики Хоара — логику разделения. Первоначальной идеей было упрощение рассуждений об императивных программах низкого уровня с общей изменяемой структурой данных[9]. Сам термин связан с основной идеей данной логики — описанием разделения хранилища (англ.storage) на непересекающиеся компоненты. Термин используется как в отношении исчисления предикатов, расширенного оператором разделения, так и для результата расширения хоаровской логики[1].
Описание
Ключевой особенностью логики разделения является возможность локальных рассуждений (local reasoning) благодаря наличию в утверждениях пространственных связок (англ.spatial connectives) между частями кучи[10].
Логика позволяет работать с утверждениями вида , где:
— куча, конечное частичное функциональное отображение из целых в целые, а
— утверждение о памяти и куче, то есть, о состоянии программы[12].
Для преодоления громоздких описаний запретов на использование одного и того же адреса разными объектами, введена новая логическая операция — разделяющая конъюнкция (disjoint conjunction), обозначаемая (или [13]) и утверждающая, что каждое из условий и выполняются в своей части кучи (адресуемого хранилища)[9][14]. То есть, истинна для кучи , если существуют две части этой кучи и , для которых выполнено[15]:
Области и не пересекаются;
является объединением и ;
верно для всех адресов из ;
верно для всех адресов из .
Выше под и понимаются частичные функции, дающие значения, соответствующие адресу в куче.
Для утверждения, что куча пуста, введён предикат (при этом очевидно выполняется ), а для обозначения указателя — . Например, в следующей, являющейся одной из аксиом, тройке Хоара
предусловием является неиспользованность ячейки памяти, которая в результате операции присваивания указывает на F, что и утверждается в постусловии[12].
Ключевым для локальных рассуждений является введённое О’Хирном рамочное правило (frame rule)[1]:
,
в котором никакая свободная переменная (англ.free variable) в не изменяется (англ.modified) под влиянием команды . Используя это правило, можно добавлять произвольные предикаты о переменных и частях кучи, которые не изменяются командой . При этом О’Хирн назвал объём занимаемой кучи, затрагиваемой командой, термином англ.footprint («отпечаток»). Назначением рамочного правила является расширение рассуждения с более локального описания команды на более глобальное описание объемлющей команды — команды с бо́льшим отпечатком[1].
Установив, что логика разделения является примером логики пучковых импликаций, Ян и Иштиак ввёл разделяющую импликацию (англ.separating implication[1], англ.magic wand). Обозначение говорит о том, если куча была расширена непересекающейся с ней кучей, для которой верно , то для получившейся в результате кучи будет верно [7].
Семантика логических связок (разделяющей конъюнкции и разделяющей импликации) подразумевает моноидную структуру кучи[7].
Локальные рассуждения можно понимать и в терминах передачи принадлежности (англ.ownership transfer). Легче всего рассмотреть передачу принадлежности на примере правил монитора Хоара (можно увидеть, что логика разделения подходит и для распределённых систем). Для входа процесса в критическую секцию применяется разделяющая конъюнкция с , где — инвариант ресурса r. По выходу из критической секции логический вывод следует в обратном направлении[16]:
,
По аналогии можно рассматривать и процесс обработки процессом сообщения, отправленного другим процессом с делегированными данному процессу ресурсами, определяемыми отпечатками[16].
Применение и реализации
Логика разделения нашла применение в автоматических и интерактивных верификаторах программного обеспечения, написанного в императивном и объектно-ориентированном стиле. Для этого были разработаны соответствующие дополнения к существующим инструментам верификации, например, таких как:
Ynot[17] — библиотека для верификации императивных программ для Coq.
Predator[18] — это анализатор программ на основе логики разделения для анализа программ, содержащих динамические списки[19].
Другие системы, использующие логику разделения: Smallfoot, Space Invader, THOR, SLAyer, HIP, jStar, Xisa, VeriFast, Infer, SeLoger, SLP. Тем не менее, по состоянию на 2014 год отсутствуют практичные доказатели теорем, реализующие полную логику разделения, то есть включающие разделяющую импликацию[7].
По характеру использования системы можно разделить следующим образом[20]:
Пользователь вручную пишет как спецификацию, так и доказательства, используя тактики: интерактивные системы доказательства теорем Coq, HOL4, Isabelle/HOL.
Пользователь пишет спецификацию и инварианты циклов: самостоятельные инструменты для верификации Smallfoot, HIP, Verifast, Jstar.
Пользователь пишет только спецификацию (или даже ничего не пишет): инструменты для анализа формы (англ.shape analysis) Space Invader, THOR, Xisa, SLAyer.
↑ Intuitionistic Reasoning about Shared Mutable Data Structure. John Reynolds. Millennial Perspectives in Computer Science, Proceedings of the 1999 Oxford-Microsoft Symposium in Honour of Sir Tony Hoare
↑ BI as an Assertion Language for Mutable Data Structures. Samin Ishtiaq, Peter O’Hearn. POPL 2001.
↑ Мутилин В. С., Новиков Е. М., Хорошилов А. В.Обзор инструментов статической верификации Си программ в применении к драйверам устройств операционной системы Linux// Труды Института системного программирования РАН.— 2012.— Т. 22, № 3.— С. 293-326.
Peter W. O’Hearn.A Primer on Separation Logic (and Automatic Program Verification and Analysis)// Software Safety and Security; Tools for Analysis and Verification.— 2012.— Vol.33.— P.286—318.
Matthew Parkinson An Introduction to Separation Logic(англ.) — презентация, в которой иллюстрированы все основные аспекты логики разделения: аксиомы, примеры программ с соответствующими диаграммами, синтаксис
Эта статья входит в число добротных статей русскоязычного раздела Википедии.
Данная страница на сайте WikiSort.ru содержит текст со страницы сайта "Википедия".
Другой контент может иметь иную лицензию. Перед использованием материалов сайта WikiSort.ru внимательно изучите правила лицензирования конкретных элементов наполнения сайта.
2019-2024 WikiSort.ru - проект по пересортировке и дополнению контента Википедии