- •Содержание
- •1.1. Программа как формализованное описание процесса обработки данных. Программное средство
- •1.2. Неконструктивность понятия правильной программы
- •1.3. Надежность программного средства
- •Технология программирования как технология разработки надежных программных средств
- •1.5. Технология программирования и информатизация общества
- •Интеллектуальные возможности человека
- •Модель перевода
- •2.4. Основные пути борьбы с ошибками
- •3.1. Специфика разработки программных средств
- •3.2. Жизненный цикл программного средства
- •3.3. Понятие качества программного средства
- •3.5. Методы борьбы со сложностью
- •3.6. Обеспечение точности перевода
- •3.7. Преодоление барьера между пользователем и разработчиком
- •3.8. Контроль принимаемых решений
- •4.1. Назначение внешнего описания программного средства и его роль в обеспечении качества программного средства
- •4.2. Определение требований к программному средству
- •4.3. Спецификация качества программного средства
- •4.4. Функциональная спецификация программного средства
- •4.5. Методы контроля внешнего описания программного средства
- •Основные подходы к спецификации семантики функций
- •5.2. Метод таблиц решений
- •5.3. Операционная семантика
- •5.4. Денотационная семантика
- •5.5. Аксиоматическая семантика
- •5.6. Языки спецификаций
- •6.1. Понятие архитектуры программного средства
- •6.2. Основные классы архитектур программных средств
- •6.3. Архитектурные функции
- •7.1. Цель модульного программирования
- •7.2. Основные характеристики программного модуля
- •7.3. Методы разработки структуры программы
- •7.4. Контроль структуры программы
- •8.1. Порядок разработки программного модуля
- •8.2. Структурное программирование
- •8.3. Пошаговая детализация и понятие о псевдокоде
- •8.4. Контроль программного модуля
- •9.1. Обоснования программ. Формализация свойств программ
- •9.2. Свойства простых операторов
- •Свойства основных конструкций структурного программирования
- •9.4. Завершимость выполнения программы
- •9.5. Пример доказательства свойства программы
- •10.1. Основные понятия
- •10.5. Комплексная отладка программного средства
- •11.1. Функциональность и надежность как обязательные критерии качества программного средства
- •11.2. Обеспечение завершенности программного средства
- •11.3. Обеспечение точности программного средства
- •11.4. Обеспечение автономности программного средства
- •11.5. Обеспечение устойчивости программного средства
- •11.6. Обеспечение защищенности программных средств
- •Все если
- •Раздел I. Общие положения
- •Раздел V.
- •9 Июля 1993 год № 5351-1
- •Глава 1. Общие положения
- •Глава 2. Исключительные авторские права
- •Глава 3. Использование программ для эвм и баз данных
- •Глава 4. Защита прав
- •1. Автор программы для эвм или базы данных и иные правообладатели вправе требовать:
- •394026 Воронеж, Московский проспект, 14
8.4. Контроль программного модуля
Применяются следующие методы контроля программного модуля:
статическая проверка текста модуля;
сквозное прослеживание;
доказательство свойств программного модуля.
При статической проверке текста модуля этот текст просматривается с начала до конца с целью найти ошибки в модуле. Обычно для такой проверки привлекают, кроме разработчика модуля, еще одного или даже нескольких программистов. Рекомендуется ошибки, обнаруживаемые при такой проверке исправлять не сразу, а по завершению чтения текста модуля.
Сквозное прослеживание представляет собой один из видов динамического контроля модуля. В нем также участвуют несколько программистов, которые вручную прокручивают выполнение модуля (оператор за оператором в той последовательности, какая вытекает из логики работы модуля) на некотором наборе тестов.
Доказательству свойств программ посвящена следующая лекция. Здесь следует лишь отметить, что этот метод применяется пока очень редко.
Вопросы для самоконтроля:
8.1. Что такое структурное программирование?
8.2. Что такое пошаговая детализация программного модуля?
8.3. Что такое псевдокод?
Литература:
8.1. Г.Майерс. Надежность программного обеспечения. - М.: Мир, 1980. - С. 127-154.
8.2. Э.Дейкстра. Заметки по структурному программированию / У.Дал, Э.Дейкстра, К.Хоор. Структурное программирование. - М.: Мир, 1975. - С. 24-97.
8.3. Н.Вирт. Систематическое программирование. - М.: Мир, 1977. - С. 94-164.
ДОКАЗАТЕЛЬСТВО СВОЙСТВ ПРОГРАММ
9.1. Обоснования программ. Формализация свойств программ
Для повышения надежности программных средств весьма полезно снабжать программы дополнительной информацией, с использованием которой можно существенно повысить уровень контроля ПС. Такую информацию можно задавать в форме неформализованных или формализованных утверждений, привязываемых к различным фрагментам программ. Будем называть такие утверждения обоснованиями программы. Неформализованные обоснования программ могут, например, объяснять мотивы принятия тех или иных решений, что может существенно облегчить поиск и исправление ошибок, а также изучение программ при их сопровождении. Формализованные же обоснования позволяют доказывать некоторые свойства программ как вручную, так и контролировать (устанавливать) их автоматически.
Одной из используемых в настоящее время концепций формальных обоснований программ является использование так называемых триад Хоора. Пусть S некоторый обобщенный оператор над информационной средой IS, а P и Q некоторые предикаты (утверждения) над этой средой. Тогда запись {P}S{Q} и называют триадой Хоора, в которой предикат P называют предусловием, а предикат Q постусловием относительно оператора S. Говорят, что оператор (в частности, программа) S обладает свойством {P}S{Q}, если всякий раз, когда перед выполнением оператора S истинен предикат P, после выполнения этого оператора S будет истинен предикат Q.
Простые примеры свойств программ:
(9.1) {n=0} n:= n+1{n=1},
(9.2) {n<m} n:= n + k {n<m+k},
(9.3) {n<m+k} n:=3n {n<3(m + k)},
{n>0} p:=1; m:=1;
ПОКА m <> n ДЕЛАТЬ
m:=m+1; p:= pm
ВСЕ ПОКА
{p= n!}.
Для доказательства свойства программы S используются свойства простых операторов языка программирования (мы здесь ограничимся пустым оператором и оператором присваивания) и свойствами управляющих конструкций (композиций), с помощью которых строится программа из простых операторов (мы здесь ограничимся тремя основными композициями структурного программирования, см. Лекцию 8). Эти свойства называют обычно правилами верификации программ.