Интернет магазин китайских планшетных компьютеров



Компьютеры - Принцип подстановки Лисков

23 января 2011


Оглавление:
1. Принцип подстановки Лисков
2. Проектирование по контракту



Принцип подстановки Лисков в объектно-ориентированном программировании является специфичным определением подтипа предложенным Барбарой Лисков в 1987 году на конференции в основном докладе под названием Абстракция данных и иерархия .

В последующей статье Лисков кратко сформулировала свой принцип следующим образом:

Пусть q является свойством, верным относительно объектов x некоторого типа T. Тогда q также должно быть верным для объектов y типа S, где S является подтипом типа T.

Таким образом, идея Лисков о «подтипе» даёт определение понятия если S является подтипом T, тогда объекты типа T в программе могут быть замещены объектами типа S без каких либо изменений желательных свойств этой программы.

Этот принцип является важнейшим критерием для оценки качества принимаемых решений при построении иерархий наследования. Сформулировать его можно в виде простого правила: тип S будет подтипом Т тогда и только тогда, когда каждому объекту oS типа S соответствует некий объект oT типа T таким образом, что для всех программ P, реализованных в терминах T, поведение P не будет меняться, если oT заменить на oS.

Более простыми словами можно сказать, что поведение наследуемых классов не должно противоречить поведению, заданному базовым классом, т.е. поведение наследуемых классов должно быть ожидаемым для кода, использующего переменную базового типа.

Саттер и Александреску в своём руководстве по использованию Си++ для выражения этого принципа также используют фразу "подкласс не должен требовать от вызывающего кода больше, чем базовый класс, и не должен предоставлять вызывающему коду меньше, чем базовый класс". По мнению данных авторов, публичное наследование в Си++ можно употреблять только тогда, когда оно удовлетворяет принципу Лисков. Приватное наследование, по их же мнению, дозволено использовать для доступа к protected части базы и перекрытия виртуальных методов. В любом же ином случае, т.е. для всего лишь повторного использования кода из базы, наследование применять нельзя.

Основания: использование публичного наследования для повторного использования кода приводит к тому, что внешний мир начинает считать класс Derived разновидностью класса Base, и возможно появление кода, явно использующего этот факт. Такое сильно сужает простор для манёвра архитектора в дальнейшем поддержании и рефакторинге класса Derived.



Просмотров: 1847


<<< Охрана (программирование)
Проверка моделей >>>